From 5e30c1d55ae2ea0cf0c43a3693e09d48512cd0df Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Tue, 4 Nov 2025 19:07:57 +0000 Subject: [PATCH 01/11] Ported deftorel pass --- spectec/src/exe-spectec/main.ml | 5 + spectec/src/il/iter.ml | 3 + spectec/src/middlend/deftorel.ml | 617 ++++++++++++++++++++++++++++++ spectec/src/middlend/deftorel.mli | 1 + spectec/src/middlend/dune | 1 + 5 files changed, 627 insertions(+) create mode 100644 spectec/src/middlend/deftorel.ml create mode 100644 spectec/src/middlend/deftorel.mli diff --git a/spectec/src/exe-spectec/main.ml b/spectec/src/exe-spectec/main.ml index c8b9b79f2e..41500e9b1b 100644 --- a/spectec/src/exe-spectec/main.ml +++ b/spectec/src/exe-spectec/main.ml @@ -27,6 +27,7 @@ type pass = | AliasDemut | ImproveIds | Ite + | DefToRel (* This list declares the intended order of passes. @@ -43,6 +44,7 @@ let all_passes = [ Else; Uncaseremoval; Sideconditions; + DefToRel; SubExpansion; Sub; AliasDemut; @@ -112,6 +114,7 @@ let pass_flag = function | Uncaseremoval -> "uncase-removal" | ImproveIds -> "improve-ids" | Ite -> "ite" + | DefToRel -> "definition-to-relation" let pass_desc = function | Sub -> "Synthesize explicit subtype coercions" @@ -126,6 +129,7 @@ let pass_desc = function | AliasDemut -> "Lifts type aliases out of mutual groups" | ImproveIds -> "Disambiguates ids used from each other" | Ite -> "If-then-else introduction" + | DefToRel -> "Transform specific function definitions into relations" let run_pass : pass -> Il.Ast.script -> Il.Ast.script = function @@ -141,6 +145,7 @@ let run_pass : pass -> Il.Ast.script -> Il.Ast.script = function | AliasDemut -> Middlend.AliasDemut.transform | ImproveIds -> Middlend.Improveids.transform | Ite -> Middlend.Ite.transform + | DefToRel -> Middlend.Deftorel.transform (* Argument parsing *) diff --git a/spectec/src/il/iter.ml b/spectec/src/il/iter.ml index e20f4eff19..783bdc849c 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 diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml new file mode 100644 index 0000000000..d7dc3a0826 --- /dev/null +++ b/spectec/src/middlend/deftorel.ml @@ -0,0 +1,617 @@ +open Il.Ast +open Il +open Util.Source + +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 env : Il.Env.t; + mutable rel_set : StringSet.t; + mutable def_arg_set : StringSet.t +} + +let empty_env = { + env = Il.Env.empty; + rel_set = StringSet.empty; + def_arg_set = StringSet.empty +} + +let fun_prefix = "fun_" + +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 free_vars = (Free.free_list Free.free_arg args).varid in + (List.fold_left (fun (free_set, acc) (iter, id_exp_pairs) -> + let new_id_exp_pairs = List.filter (fun (id, _) -> + Free.Set.mem id.it free_set + ) id_exp_pairs in + if new_id_exp_pairs = [] 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 collect_fcalls_exp iter_quants 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 iter_quants in + ((fun_prefix ^ id.it $ id.at, args, e.note), new_iter_quants, List.length new_iter_quants) :: + List.concat_map (collect_fcalls_arg iter_quants env) args + | CallE (_, args) -> List.concat_map (collect_fcalls_arg iter_quants env) args + | StrE fields -> List.concat_map (fun (_a, e1) -> collect_fcalls_exp iter_quants env e1) fields + | UnE (_, _, e1) | CvtE (e1, _, _) | LiftE e1 | TheE e1 | OptE (Some e1) + | ProjE (e1, _) | UncaseE (e1, _) + | CaseE (_, e1) | LenE e1 | DotE (e1, _) + | SubE (e1, _, _) -> collect_fcalls_exp iter_quants env e1 + | BinE (_, _, e1, e2) | CmpE (_, _, e1, e2) + | CompE (e1, e2) | MemE (e1, e2) + | CatE (e1, e2) | IdxE (e1, e2) -> collect_fcalls_exp iter_quants env e1 @ collect_fcalls_exp iter_quants env e2 + | TupE exps | ListE exps -> List.concat_map (collect_fcalls_exp iter_quants env) exps + | SliceE (e1, e2, e3) -> collect_fcalls_exp iter_quants env e1 @ collect_fcalls_exp iter_quants env e2 @ collect_fcalls_exp iter_quants env e3 + | UpdE (e1, p, e2) + | ExtE (e1, p, e2) -> collect_fcalls_exp iter_quants env e1 @ collect_fcalls_path iter_quants env p @ collect_fcalls_exp iter_quants env e2 + | IterE (e1,( (iter, id_exp_pairs) as iterexp)) -> + collect_fcalls_exp (iterexp :: iter_quants) env e1 @ collect_fcalls_iter (iterexp :: iter_quants) env iter @ + List.concat_map (fun (_, exp) -> collect_fcalls_exp iter_quants env exp) id_exp_pairs + | _ -> [] + +and collect_fcalls_iter iter_quants env i = + match i with + | ListN (e1, _) -> collect_fcalls_exp iter_quants env e1 + | _ -> [] + +and collect_fcalls_arg iter_quants env a = + match a.it with + | ExpA exp -> collect_fcalls_exp iter_quants env exp + | _ -> (* TODO - possibly need to go through all types of args *) + [] + +and collect_fcalls_prem iter_quants env p = + match p.it with + | IfPr e | RulePr (_, _, _, e) -> collect_fcalls_exp iter_quants env e + | LetPr (e1, e2, _) -> collect_fcalls_exp iter_quants env e1 @ collect_fcalls_exp iter_quants env e2 + | IterPr (p', iterexp) -> collect_fcalls_prem (iterexp :: iter_quants) env p' + | _ -> [] + +and collect_fcalls_path iter_quants env p = + match p.it with + | RootP -> [] + | IdxP (p, e) -> collect_fcalls_path iter_quants env p @ collect_fcalls_exp iter_quants env e + | SliceP (p, e1, e2) -> collect_fcalls_path iter_quants env p @ collect_fcalls_exp iter_quants env e1 @ collect_fcalls_exp iter_quants env e2 + | DotP (p, _) -> collect_fcalls_path iter_quants env p + +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 + | 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 (e1, e2, ids) -> + (* 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 (e1', e2', ids), 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 fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) 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 fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) 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) (new_prems @ prems)) + ) $ clause.at + +let transform_prod env prod = + match prod.it with + | ProdD (quants, sym, exp, prems) -> + let fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) 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 rec has_sub_exp e = + match e.it with + | SubE _ -> true + | StrE fields -> List.exists (fun (_a, e1) -> has_sub_exp e1) fields + | UnE (_, _, e1) | CvtE (e1, _, _) | LiftE e1 | TheE e1 | OptE (Some e1) + | ProjE (e1, _) | UncaseE (e1, _) + | CaseE (_, e1) | LenE e1 | DotE (e1, _) -> has_sub_exp e1 + | BinE (_, _, e1, e2) | CmpE (_, _, e1, e2) + | CompE (e1, e2) | MemE (e1, e2) + | CatE (e1, e2) | IdxE (e1, e2) -> has_sub_exp e1 || has_sub_exp e2 + | TupE exps | ListE exps -> List.exists has_sub_exp exps + | SliceE (e1, e2, e3) -> has_sub_exp e1 || has_sub_exp e2 || has_sub_exp e3 + | UpdE (e1, p, e2) + | ExtE (e1, p, e2) -> has_sub_exp e1 || has_sub_exp_path p || has_sub_exp e2 + | CallE (_id, args) -> List.exists has_sub_exp_arg args + | IterE (e1, (_, id_exp_pairs)) -> has_sub_exp e1 || List.exists (fun (_, exp) -> has_sub_exp exp) id_exp_pairs + | _ -> false + +and has_sub_exp_arg a = + match a.it with + | ExpA e -> has_sub_exp e + | _ -> false + +and has_sub_exp_path p = + match p.it with + | RootP -> false + | IdxP (p, e) -> has_sub_exp_path p || has_sub_exp e + | SliceP (p, e1, e2) -> has_sub_exp_path p || has_sub_exp e1 || has_sub_exp e2 + | DotP (p, _) -> has_sub_exp_path p + +let rec utilizes_rel_def env e = + match e.it with + | CallE (id, args) -> StringSet.mem id.it env.rel_set || List.exists (utilizes_rel_def_arg env) args + | StrE fields -> List.exists (fun (_a, e1) -> utilizes_rel_def env e1) fields + | UnE (_, _, e1) | CvtE (e1, _, _) | LiftE e1 | TheE e1 | OptE (Some e1) + | ProjE (e1, _) | UncaseE (e1, _) + | CaseE (_, e1) | LenE e1 | DotE (e1, _) + | SubE (e1, _, _) -> utilizes_rel_def env e1 + | BinE (_, _, e1, e2) | CmpE (_, _, e1, e2) + | CompE (e1, e2) | MemE (e1, e2) + | CatE (e1, e2) | IdxE (e1, e2) -> utilizes_rel_def env e1 || utilizes_rel_def env e2 + | TupE exps | ListE exps -> List.exists (utilizes_rel_def env) exps + | SliceE (e1, e2, e3) -> utilizes_rel_def env e1 || utilizes_rel_def env e2 || utilizes_rel_def env e3 + | UpdE (e1, p, e2) + | ExtE (e1, p, e2) -> utilizes_rel_def env e1 || utilizes_rel_def_path env p || utilizes_rel_def env e2 + | IterE (e1, (_, id_exp_pairs)) -> utilizes_rel_def env e1 || List.exists (fun (_, exp) -> utilizes_rel_def env exp) id_exp_pairs + | _ -> false + +and utilizes_rel_def_arg env a = + match a.it with + | ExpA e -> utilizes_rel_def env e + | _ -> false + +and utilizes_rel_def_path env p = + match p.it with + | RootP -> false + | IdxP (p, e) -> utilizes_rel_def_path env p || utilizes_rel_def env e + | SliceP (p, e1, e2) -> utilizes_rel_def_path env p || utilizes_rel_def env e1 || utilizes_rel_def env e2 + | DotP (p, _) -> utilizes_rel_def_path env p + +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 listn_set, (module Arg : Iter.Arg) = collect_list_length_vars () 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; + (* Can't have subtyping matching *) + List.exists has_sub_exp_arg args || + (* Premises might not be decidable *) + prems <> [] || + (* Functions that have function calls transformed to relations must also be relations *) + utilizes_rel_def env exp || + (* 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 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 tupt = TupT (List.map (fun t -> "_" $ id.at, t) types) $ id.at 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 exps = List.map get_exp_arg args in + let fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) prems in + let call_map, new_quants, new_prems = create_call_map fcalls quants in + let tupe = TupE (exps @ [transform_exp_normal call_map env exp]) $$ id.at % tupt in + RuleD (fun_prefix ^ id.it ^ "_case_" ^ Int.to_string i $ id.at, quants @ new_quants, new_mixop, tupe, List.map (transform_prem_normal call_map env) (new_prems @ prems)) $ id.at + ) clauses + in + RelD (fun_prefix ^ id.it $ id.at, [], new_mixop, tupt, rules) + +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) -> + 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) -> + DecD (id, params, typ, List.map (transform_clause env) clauses) + | RecD defs when List.exists must_be_rel_def defs && List.for_all has_exp_params defs -> + List.iter (fun d -> match d.it with + | DecD (id, _, _, _) -> env.rel_set <- StringSet.add id.it env.rel_set + | _ -> () + ) defs; + RecD (List.map (transform_def env) defs) + | RecD defs -> RecD (List.map (transform_def env) defs) + | GramD (id, params, typ, prods) -> 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 transform (il : script): script = + let env = empty_env in + env.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; + env.def_arg_set <- !acc; + List.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 c2bc064072..101426c60f 100644 --- a/spectec/src/middlend/dune +++ b/spectec/src/middlend/dune @@ -15,5 +15,6 @@ aliasDemut improveids ite + deftorel ) ) From d612cfc00097b7e311798288d147b78928e4b475 Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Tue, 18 Nov 2025 16:49:00 +0000 Subject: [PATCH 02/11] Added fallthrough semantics to converted defs, which conveniently handles otherwise. --- spectec/src/middlend/deftorel.ml | 85 ++++++++++++++++++++++++++------ spectec/src/middlend/utils.ml | 7 +++ 2 files changed, 76 insertions(+), 16 deletions(-) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index d7dc3a0826..c568226779 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -1,6 +1,7 @@ open Il.Ast open Il open Util.Source +open Util module StringSet = Set.Make(String) @@ -12,13 +13,13 @@ module ExpMap = Map.Make(struct end) type env = { - mutable env : Il.Env.t; + mutable il_env : Il.Env.t; mutable rel_set : StringSet.t; mutable def_arg_set : StringSet.t } let empty_env = { - env = Il.Env.empty; + il_env = Il.Env.empty; rel_set = StringSet.empty; def_arg_set = StringSet.empty } @@ -289,7 +290,6 @@ and transform_exp call_map env e: (exp * (id * typ * int) list) = | 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, [] @@ -307,7 +307,9 @@ and transform_path call_map env path = 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) -> @@ -499,6 +501,16 @@ and utilizes_rel_def_path env p = | SliceP (p, e1, e2) -> utilizes_rel_def_path env p || utilizes_rel_def env e1 || utilizes_rel_def env e2 | DotP (p, _) -> utilizes_rel_def_path env p +and utilizes_rel_def_prem env p = + match p.it with + | IfPr e -> utilizes_rel_def env e + | RulePr (_, _, _, e) -> utilizes_rel_def env e + | LetPr (e1, e2, _) -> utilizes_rel_def env e1 || utilizes_rel_def env e2 + | IterPr (p', (_, id_exp_pairs)) -> + utilizes_rel_def_prem env p' || + List.exists (fun (_, exp) -> utilizes_rel_def env exp) id_exp_pairs + | _ -> false + let collect_list_length_vars () : StringSet.t ref * (module Iter.Arg) = let module Arg = struct @@ -530,6 +542,7 @@ let must_be_relation env id params clauses = prems <> [] || (* Functions that have function calls transformed to relations must also be relations *) utilizes_rel_def env exp || + List.exists (utilizes_rel_def_prem env) 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 @@ -543,6 +556,45 @@ let must_be_relation env id params clauses = !listn_set <> StringSet.empty ) clauses +let get_tuple_exp e = + match e.it with + | TupE exps -> exps + | _ -> [e] + +let generate_matching_rules env args tupt r = + match r.it with + | RuleD (id, binds, 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, binds, List.tl mixop, new_exp, prems)}) + +let tail_mixop mixop = + match mixop with + | Xl.Mixop.Seq xs -> Xl.Mixop.Seq (List.tl xs) + | _ -> mixop + +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, binds, m, exp, prems); _} as r) :: rs -> + 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, binds, 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, binds, m, exp, negrulepr :: prems') } in + relation :: go (new_rule :: prev_rules) rs + in + go [] rules let cvt_def_to_rel env id params r_typ clauses = let get_param_typ p = @@ -551,19 +603,20 @@ let cvt_def_to_rel env id params r_typ clauses = | _ -> assert false in let types = List.map get_param_typ params @ [r_typ] in - let tupt = TupT (List.map (fun t -> "_" $ id.at, t) types) $ id.at in - let new_mixop = Xl.Mixop.(Seq (List.init (List.length params + 1) (fun _ -> Arg ()))) 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 exps = List.map get_exp_arg args in let fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) prems in let call_map, new_quants, new_prems = create_call_map fcalls quants in - let tupe = TupE (exps @ [transform_exp_normal call_map env exp]) $$ id.at % tupt 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_mixop, tupe, List.map (transform_prem_normal call_map env) (new_prems @ prems)) $ id.at ) clauses in - RelD (fun_prefix ^ id.it $ id.at, [], new_mixop, tupt, rules) + let new_id = { id with it = fun_prefix ^ id.it } in + fall_through_prems env new_id new_mixop tup_types rules let rec transform_def (env : env) def = let must_be_rel_def d = @@ -578,22 +631,22 @@ let rec transform_def (env : env) def = in (match def.it with | RelD (id, qs, m, typ, rules) -> - RelD (id, qs, m, typ, List.map (transform_rule env) 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) -> - DecD (id, params, typ, List.map (transform_clause env) clauses) + [{ def with it = DecD (id, params, typ, List.map (transform_clause env) clauses) }] | RecD defs when List.exists must_be_rel_def defs && List.for_all has_exp_params defs -> List.iter (fun d -> match d.it with | DecD (id, _, _, _) -> env.rel_set <- StringSet.add id.it env.rel_set | _ -> () ) defs; - RecD (List.map (transform_def env) defs) - | RecD defs -> RecD (List.map (transform_def env) defs) - | GramD (id, params, typ, prods) -> GramD (id, params, typ, List.map (transform_prod env) prods) - | d -> d - ) $ def.at + [{ def with it = RecD (List.concat_map (transform_def env) 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 = @@ -609,9 +662,9 @@ let collect_def_args (): StringSet.t ref * (module Iter.Arg) = let transform (il : script): script = let env = empty_env in - env.env <- Il.Env.env_of_script il; + 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; env.def_arg_set <- !acc; - List.map (transform_def env) il \ No newline at end of file + List.concat_map (transform_def env) il \ No newline at end of file diff --git a/spectec/src/middlend/utils.ml b/spectec/src/middlend/utils.ml index 2096591915..116c4420ee 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_bind (free_set : Free.sets) b = + match b.it with + | ExpB (id, _) -> Free.Set.mem id.it free_set.varid + | TypB id -> Free.Set.mem id.it free_set.typid + | DefB (id, _, _) -> Free.Set.mem id.it free_set.defid + | GramB (id, _, _) -> Free.Set.mem id.it free_set.gramid + let generate_var ids id = let start = 0 in let fresh_prefix = "var" in From c769c77524469b7ebc8480dd69eae14179bdb315 Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Mon, 8 Dec 2025 16:14:44 +0000 Subject: [PATCH 03/11] Remove created relations out of recursive groups if they don't call the recursive functions themselves. --- spectec/src/middlend/deftorel.ml | 32 ++++++++++++++++++++++++-------- 1 file changed, 24 insertions(+), 8 deletions(-) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index c568226779..c212a2373d 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -561,18 +561,20 @@ let get_tuple_exp e = | TupE exps -> exps | _ -> [e] +let tail_mixop mixop = + match mixop with + | Xl.Mixop.Seq xs -> Xl.Mixop.Seq (List.tl xs) + | _ -> mixop + let generate_matching_rules env args tupt r = match r.it with | RuleD (id, binds, 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, binds, List.tl mixop, new_exp, prems)}) - -let tail_mixop mixop = - match mixop with - | Xl.Mixop.Seq xs -> Xl.Mixop.Seq (List.tl xs) - | _ -> mixop + Option.map (fun _ -> + {r with it = RuleD (id, binds, tail_mixop mixop, new_exp, prems)} + ) let fall_through_prems env id mixop typs rules = let gen_rel_name rid = @@ -618,6 +620,13 @@ let cvt_def_to_rel env id params r_typ clauses = 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 @@ -638,11 +647,18 @@ let rec transform_def (env : env) def = | DecD (id, params, typ, clauses) -> [{ def with it = DecD (id, params, typ, List.map (transform_clause env) clauses) }] | RecD defs when List.exists must_be_rel_def defs && List.for_all has_exp_params defs -> + let ids_ref = ref StringSet.empty in List.iter (fun d -> match d.it with - | DecD (id, _, _, _) -> env.rel_set <- StringSet.add id.it env.rel_set + | DecD (id, _, _, _) -> + ids_ref := StringSet.add (fun_prefix ^ id.it) !ids_ref; + env.rel_set <- StringSet.add id.it env.rel_set | _ -> () ) defs; - [{ def with it = RecD (List.concat_map (transform_def env) 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] From 6f5792e01f1d62df68f4719e29ecb70cca78992d Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Mon, 8 Dec 2025 17:04:45 +0000 Subject: [PATCH 04/11] Added a filter to the prems from the generated fallthrough relations that removes ones that have reference to the return expression. --- spectec/src/middlend/deftorel.ml | 30 +++++++++++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index c212a2373d..09ace140cf 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -566,6 +566,34 @@ let tail_mixop mixop = | 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 the premises following it. It assumes that the premises are in order (at the very least, + that function calls return variables are not used beforehand) which is true by the construction above. + 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 prems = + let pred p ps = + match p.it with + | RulePr (id, _, _, {it = TupE exps; _}) when String.starts_with ~prefix:fun_prefix id.it -> + 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 ps -> p :: filter_return_prems ps + | _ :: ps -> filter_return_prems ps + let generate_matching_rules env args tupt r = match r.it with | RuleD (id, binds, mixop, exp', prems) -> @@ -573,7 +601,7 @@ let generate_matching_rules env args tupt r = 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, binds, tail_mixop mixop, new_exp, prems)} + {r with it = RuleD (id, binds, tail_mixop mixop, new_exp, filter_return_prems prems)} ) let fall_through_prems env id mixop typs rules = From c5334ccff5625f563fed1d8a09ef179e34b1c17e Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Tue, 20 Jan 2026 14:51:39 +0000 Subject: [PATCH 05/11] Made fallthrough only when otherwise is present. Refactored a bit using new traversal method --- spectec/src/middlend/deftorel.ml | 141 ++++++++++--------------------- spectec/src/middlend/utils.ml | 10 +-- 2 files changed, 51 insertions(+), 100 deletions(-) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index 09ace140cf..0c7a234b3d 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -1,5 +1,6 @@ open Il.Ast open Il +open Il.Walk open Util.Source open Util @@ -59,54 +60,28 @@ let filter_iter_quants args iter_quants = ) (free_vars, []) iter_quants) |> snd |> List.rev -let rec collect_fcalls_exp iter_quants env e = +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 iter_quants in - ((fun_prefix ^ id.it $ id.at, args, e.note), new_iter_quants, List.length new_iter_quants) :: - List.concat_map (collect_fcalls_arg iter_quants env) args - | CallE (_, args) -> List.concat_map (collect_fcalls_arg iter_quants env) args - | StrE fields -> List.concat_map (fun (_a, e1) -> collect_fcalls_exp iter_quants env e1) fields - | UnE (_, _, e1) | CvtE (e1, _, _) | LiftE e1 | TheE e1 | OptE (Some e1) - | ProjE (e1, _) | UncaseE (e1, _) - | CaseE (_, e1) | LenE e1 | DotE (e1, _) - | SubE (e1, _, _) -> collect_fcalls_exp iter_quants env e1 - | BinE (_, _, e1, e2) | CmpE (_, _, e1, e2) - | CompE (e1, e2) | MemE (e1, e2) - | CatE (e1, e2) | IdxE (e1, e2) -> collect_fcalls_exp iter_quants env e1 @ collect_fcalls_exp iter_quants env e2 - | TupE exps | ListE exps -> List.concat_map (collect_fcalls_exp iter_quants env) exps - | SliceE (e1, e2, e3) -> collect_fcalls_exp iter_quants env e1 @ collect_fcalls_exp iter_quants env e2 @ collect_fcalls_exp iter_quants env e3 - | UpdE (e1, p, e2) - | ExtE (e1, p, e2) -> collect_fcalls_exp iter_quants env e1 @ collect_fcalls_path iter_quants env p @ collect_fcalls_exp iter_quants env e2 - | IterE (e1,( (iter, id_exp_pairs) as iterexp)) -> - collect_fcalls_exp (iterexp :: iter_quants) env e1 @ collect_fcalls_iter (iterexp :: iter_quants) env iter @ - List.concat_map (fun (_, exp) -> collect_fcalls_exp iter_quants env exp) id_exp_pairs - | _ -> [] - -and collect_fcalls_iter iter_quants env i = - match i with - | ListN (e1, _) -> collect_fcalls_exp iter_quants env e1 - | _ -> [] - -and collect_fcalls_arg iter_quants env a = - match a.it with - | ExpA exp -> collect_fcalls_exp iter_quants env exp - | _ -> (* TODO - possibly need to go through all types of args *) - [] - -and collect_fcalls_prem iter_quants env p = - match p.it with - | IfPr e | RulePr (_, _, _, e) -> collect_fcalls_exp iter_quants env e - | LetPr (e1, e2, _) -> collect_fcalls_exp iter_quants env e1 @ collect_fcalls_exp iter_quants env e2 - | IterPr (p', iterexp) -> collect_fcalls_prem (iterexp :: iter_quants) env p' - | _ -> [] - -and collect_fcalls_path iter_quants env p = + 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 - | RootP -> [] - | IdxP (p, e) -> collect_fcalls_path iter_quants env p @ collect_fcalls_exp iter_quants env e - | SliceP (p, e1, e2) -> collect_fcalls_path iter_quants env p @ collect_fcalls_exp iter_quants env e1 @ collect_fcalls_exp iter_quants env e2 - | DotP (p, _) -> collect_fcalls_path iter_quants env p + | 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 @@ -404,8 +379,9 @@ and transform_prem_normal call_map env prem = fst (transform_prem call_map env p let transform_rule env rule = (match rule.it with - | RuleD (id, quants, m, exp, prems) -> - let fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) prems in + | 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), @@ -417,7 +393,8 @@ let transform_rule env rule = let transform_clause env clause = (match clause.it with | DefD (quants, args, exp, prems) -> - let fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) prems 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 quants in DefD ( List.map (transform_param call_map env) (quants @ new_quants), @@ -429,7 +406,8 @@ let transform_clause env clause = let transform_prod env prod = match prod.it with | ProdD (quants, sym, exp, prems) -> - let fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) prems 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 quants in ProdD (List.map (transform_param call_map env) (quants @ new_quants), sym, @@ -471,45 +449,10 @@ and has_sub_exp_path p = | SliceP (p, e1, e2) -> has_sub_exp_path p || has_sub_exp e1 || has_sub_exp e2 | DotP (p, _) -> has_sub_exp_path p -let rec utilizes_rel_def env e = +let utilizes_rel_def env e = match e.it with - | CallE (id, args) -> StringSet.mem id.it env.rel_set || List.exists (utilizes_rel_def_arg env) args - | StrE fields -> List.exists (fun (_a, e1) -> utilizes_rel_def env e1) fields - | UnE (_, _, e1) | CvtE (e1, _, _) | LiftE e1 | TheE e1 | OptE (Some e1) - | ProjE (e1, _) | UncaseE (e1, _) - | CaseE (_, e1) | LenE e1 | DotE (e1, _) - | SubE (e1, _, _) -> utilizes_rel_def env e1 - | BinE (_, _, e1, e2) | CmpE (_, _, e1, e2) - | CompE (e1, e2) | MemE (e1, e2) - | CatE (e1, e2) | IdxE (e1, e2) -> utilizes_rel_def env e1 || utilizes_rel_def env e2 - | TupE exps | ListE exps -> List.exists (utilizes_rel_def env) exps - | SliceE (e1, e2, e3) -> utilizes_rel_def env e1 || utilizes_rel_def env e2 || utilizes_rel_def env e3 - | UpdE (e1, p, e2) - | ExtE (e1, p, e2) -> utilizes_rel_def env e1 || utilizes_rel_def_path env p || utilizes_rel_def env e2 - | IterE (e1, (_, id_exp_pairs)) -> utilizes_rel_def env e1 || List.exists (fun (_, exp) -> utilizes_rel_def env exp) id_exp_pairs - | _ -> false - -and utilizes_rel_def_arg env a = - match a.it with - | ExpA e -> utilizes_rel_def env e - | _ -> false - -and utilizes_rel_def_path env p = - match p.it with - | RootP -> false - | IdxP (p, e) -> utilizes_rel_def_path env p || utilizes_rel_def env e - | SliceP (p, e1, e2) -> utilizes_rel_def_path env p || utilizes_rel_def env e1 || utilizes_rel_def env e2 - | DotP (p, _) -> utilizes_rel_def_path env p - -and utilizes_rel_def_prem env p = - match p.it with - | IfPr e -> utilizes_rel_def env e - | RulePr (_, _, _, e) -> utilizes_rel_def env e - | LetPr (e1, e2, _) -> utilizes_rel_def env e1 || utilizes_rel_def env e2 - | IterPr (p', (_, id_exp_pairs)) -> - utilizes_rel_def_prem env p' || - List.exists (fun (_, exp) -> utilizes_rel_def env exp) id_exp_pairs - | _ -> false + | 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 = @@ -526,6 +469,7 @@ let collect_list_length_vars () : StringSet.t ref * (module Iter.Arg) = let must_be_relation env id params clauses = 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. @@ -541,8 +485,8 @@ let must_be_relation env id params clauses = (* Premises might not be decidable *) prems <> [] || (* Functions that have function calls transformed to relations must also be relations *) - utilizes_rel_def env exp || - List.exists (utilizes_rel_def_prem env) prems || + 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 @@ -596,21 +540,26 @@ let rec filter_return_prems prems = let generate_matching_rules env args tupt r = match r.it with - | RuleD (id, binds, mixop, exp', prems) -> + | 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, binds, tail_mixop mixop, new_exp, filter_return_prems prems)} + {r with it = RuleD (id, quants, tail_mixop mixop, new_exp, filter_return_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, binds, m, exp, prems); _} as r) :: rs -> + | ({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 @@ -618,11 +567,12 @@ let fall_through_prems env id mixop typs 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, binds, m, exp, prems') } :: prev_rules) rs else + 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, binds, m, exp, negrulepr :: prems') } 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 @@ -639,7 +589,8 @@ let cvt_def_to_rel env id params r_typ clauses = match clause.it with | DefD (quants, args, exp, prems) -> let exps = List.map get_exp_arg args in - let fcalls = collect_fcalls_exp [] env exp @ List.concat_map (collect_fcalls_prem [] env) prems 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 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_mixop, tupe, List.map (transform_prem_normal call_map env) (new_prems @ prems)) $ id.at diff --git a/spectec/src/middlend/utils.ml b/spectec/src/middlend/utils.ml index 116c4420ee..82dd40a513 100644 --- a/spectec/src/middlend/utils.ml +++ b/spectec/src/middlend/utils.ml @@ -31,12 +31,12 @@ and reduce_inst_alias env args inst base_typ = ) | _ -> base_typ -let is_part_of_bind (free_set : Free.sets) b = +let is_part_of_quant (free_set : Free.sets) b = match b.it with - | ExpB (id, _) -> Free.Set.mem id.it free_set.varid - | TypB id -> Free.Set.mem id.it free_set.typid - | DefB (id, _, _) -> Free.Set.mem id.it free_set.defid - | GramB (id, _, _) -> Free.Set.mem id.it free_set.gramid + | 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 From 8807e55ee1fd10c099e41ae181e7b2ac80c535dd Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Tue, 20 Jan 2026 14:52:56 +0000 Subject: [PATCH 06/11] Removed subtyping matching check --- spectec/src/middlend/deftorel.ml | 32 -------------------------------- 1 file changed, 32 deletions(-) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index 0c7a234b3d..a51142affb 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -419,36 +419,6 @@ let is_exp_param param = | ExpP _ -> true | _ -> false -let rec has_sub_exp e = - match e.it with - | SubE _ -> true - | StrE fields -> List.exists (fun (_a, e1) -> has_sub_exp e1) fields - | UnE (_, _, e1) | CvtE (e1, _, _) | LiftE e1 | TheE e1 | OptE (Some e1) - | ProjE (e1, _) | UncaseE (e1, _) - | CaseE (_, e1) | LenE e1 | DotE (e1, _) -> has_sub_exp e1 - | BinE (_, _, e1, e2) | CmpE (_, _, e1, e2) - | CompE (e1, e2) | MemE (e1, e2) - | CatE (e1, e2) | IdxE (e1, e2) -> has_sub_exp e1 || has_sub_exp e2 - | TupE exps | ListE exps -> List.exists has_sub_exp exps - | SliceE (e1, e2, e3) -> has_sub_exp e1 || has_sub_exp e2 || has_sub_exp e3 - | UpdE (e1, p, e2) - | ExtE (e1, p, e2) -> has_sub_exp e1 || has_sub_exp_path p || has_sub_exp e2 - | CallE (_id, args) -> List.exists has_sub_exp_arg args - | IterE (e1, (_, id_exp_pairs)) -> has_sub_exp e1 || List.exists (fun (_, exp) -> has_sub_exp exp) id_exp_pairs - | _ -> false - -and has_sub_exp_arg a = - match a.it with - | ExpA e -> has_sub_exp e - | _ -> false - -and has_sub_exp_path p = - match p.it with - | RootP -> false - | IdxP (p, e) -> has_sub_exp_path p || has_sub_exp e - | SliceP (p, e1, e2) -> has_sub_exp_path p || has_sub_exp e1 || has_sub_exp e2 - | DotP (p, _) -> has_sub_exp_path p - let utilizes_rel_def env e = match e.it with | CallE (id, _) -> (StringSet.mem id.it env.rel_set, true) @@ -480,8 +450,6 @@ let must_be_relation env id params clauses = List.exists (fun c -> match c.it with | DefD (quants, args, exp, prems) -> Acc.args args; - (* Can't have subtyping matching *) - List.exists has_sub_exp_arg args || (* Premises might not be decidable *) prems <> [] || (* Functions that have function calls transformed to relations must also be relations *) From b25aaba3bebfc64e390f57cfd2aa4fb61289b8af Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Tue, 20 Jan 2026 14:56:51 +0000 Subject: [PATCH 07/11] reordering so generated deftorel relations get implicit sideconditions. Fix tests --- spectec/src/exe-spectec/main.ml | 4 +- spectec/src/middlend/deftorel.ml | 40 +- spectec/test-middlend/dune.inc | 11 +- ...8-sub-expansion.il => 07-sub-expansion.il} | 431 +- .../{09-sub.il => 08-sub.il} | 431 +- ...-demut.il => 09-definition-to-relation.il} | 8376 ++++-- ...sideconditions.il => 10-sideconditions.il} | 12946 +++++++-- .../specification.exp/11-alias-demut.il | 24137 ++++++++++++++++ .../{11-improve-ids.il => 12-improve-ids.il} | 8184 ++++-- spectec/test-middlend/test.spectec.exp | 202 +- 10 files changed, 45716 insertions(+), 9046 deletions(-) rename spectec/test-middlend/specification.exp/{08-sub-expansion.il => 07-sub-expansion.il} (98%) rename spectec/test-middlend/specification.exp/{09-sub.il => 08-sub.il} (98%) rename spectec/test-middlend/specification.exp/{10-alias-demut.il => 09-definition-to-relation.il} (77%) rename spectec/test-middlend/specification.exp/{07-sideconditions.il => 10-sideconditions.il} (55%) create mode 100644 spectec/test-middlend/specification.exp/11-alias-demut.il rename spectec/test-middlend/specification.exp/{11-improve-ids.il => 12-improve-ids.il} (77%) diff --git a/spectec/src/exe-spectec/main.ml b/spectec/src/exe-spectec/main.ml index 41500e9b1b..f4b9b3bf14 100644 --- a/spectec/src/exe-spectec/main.ml +++ b/spectec/src/exe-spectec/main.ml @@ -43,10 +43,10 @@ let all_passes = [ Totalize; Else; Uncaseremoval; - Sideconditions; - DefToRel; SubExpansion; Sub; + DefToRel; + Sideconditions; AliasDemut; ImproveIds ] diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index a51142affb..c6c3e05523 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -46,19 +46,34 @@ let transform_typ_iter i = | _ -> 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) -> + (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 - if new_id_exp_pairs = [] then (free_set, acc) else + + (* 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 + ) 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) + (new_set, (iter, new_id_exp_pairs') :: acc) ) (free_vars, []) iter_quants) - |> snd |> List.rev + |> snd |> List.rev let rec create_collector iterexps env = let base_collector_iters = base_collector [] (@) in @@ -262,6 +277,11 @@ and transform_exp call_map env e: (exp * (id * typ * int) list) = 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 @@ -344,11 +364,11 @@ let rec transform_prem call_map env prem = | IfPr e -> let e', iter_ids = transform_exp call_map env e in IfPr e', iter_ids - | LetPr (e1, e2, 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 (e1', e2', ids), iter_ids @ iter_ids2 + 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 @@ -387,7 +407,7 @@ let transform_rule env rule = 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)) + List.map (transform_prem_normal call_map env) (prems @ new_prems)) ) $ rule.at let transform_clause env clause = @@ -400,7 +420,7 @@ let transform_clause env clause = 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) (new_prems @ prems)) + List.map (transform_prem_normal call_map env) (prems @ new_prems)) ) $ clause.at let transform_prod env prod = @@ -412,7 +432,7 @@ let transform_prod env prod = 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 + List.map (transform_prem_normal call_map env) (prems @ new_prems)) $ prod.at let is_exp_param param = match param.it with diff --git a/spectec/test-middlend/dune.inc b/spectec/test-middlend/dune.inc index e2588b991f..77b46dda81 100644 --- a/spectec/test-middlend/dune.inc +++ b/spectec/test-middlend/dune.inc @@ -5,8 +5,9 @@ (rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/04-totalize.il specification.act/04-totalize.il)))) (rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/05-else.il specification.act/05-else.il)))) (rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/06-uncase-removal.il specification.act/06-uncase-removal.il)))) -(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/07-sideconditions.il specification.act/07-sideconditions.il)))) -(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/08-sub-expansion.il specification.act/08-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.il specification.act/09-sub.il)))) -(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/10-alias-demut.il specification.act/10-alias-demut.il)))) -(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/11-improve-ids.il specification.act/11-improve-ids.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/07-sub-expansion.il specification.act/07-sub-expansion.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/08-sub.il specification.act/08-sub.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/09-definition-to-relation.il specification.act/09-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/10-sideconditions.il specification.act/10-sideconditions.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/11-alias-demut.il specification.act/11-alias-demut.il)))) +(rule (alias runtest) (deps (alias dune.inc) (file specification.act) (glob_files_rec specification.exp/*)) (action (no-infer (diff specification.exp/12-improve-ids.il specification.act/12-improve-ids.il)))) diff --git a/spectec/test-middlend/specification.exp/08-sub-expansion.il b/spectec/test-middlend/specification.exp/07-sub-expansion.il similarity index 98% rename from spectec/test-middlend/specification.exp/08-sub-expansion.il rename to spectec/test-middlend/specification.exp/07-sub-expansion.il index 2f555f509d..6e9296aef5 100644 --- a/spectec/test-middlend/specification.exp/08-sub-expansion.il +++ b/spectec/test-middlend/specification.exp/07-sub-expansion.il @@ -1171,6 +1171,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 @@ -4359,7 +4360,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 @@ -5258,7 +5258,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) `%|-%:OK`(C, _IDX_typeuse(typeidx)) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 @@ -5267,7 +5266,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) -- wf_context: `%`(C) -- wf_subtype: `%`(st) -- wf_typeuse: `%`(REC_typeuse(i)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = st) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:114.1-116.35 @@ -5340,12 +5338,10 @@ relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) `%|-%:%`(C, SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype), OK_oktypenat(i)) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) - -- if (|`comptype'*`| = |`typeuse'**`|) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} -- (if $before(typeuse, i))*{typeuse <- `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'*`} @@ -5385,7 +5381,6 @@ relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) -- 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*`}))) - -- if (|`ft_1*`| = |`ft_2*`|) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:185.1-187.38 @@ -5419,7 +5414,6 @@ relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- 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)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 @@ -5505,7 +5499,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, (C.TYPES_context[$proj_uN_0(typeidx).0] : deftype <: heaptype), heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 @@ -5514,7 +5507,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 @@ -5524,7 +5516,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(STRUCT_heaptype) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 @@ -5534,7 +5525,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(ARRAY_heaptype) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 @@ -5544,17 +5534,14 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- 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*`})))) - -- 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*`})))) ;; ../../../../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*`}|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:81.1-84.25 @@ -5663,7 +5650,6 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} -- (wf_valtype: `%`(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*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:150.1-150.119 @@ -5721,8 +5707,6 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) -- wf_instrtype: `%`(`%->_%%`_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*`} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5740,7 +5724,6 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5762,12 +5745,9 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) - -- if (|`comptype'*`| = |`yy**`|) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} -- if (|x*{x <- `x*`}| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} - -- if (|`comptype'*`| = |`x*`|) - -- (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'*`} @@ -5896,8 +5876,6 @@ 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*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec @@ -6028,7 +6006,6 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6039,10 +6016,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`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]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6051,10 +6025,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`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]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6062,7 +6033,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) `%|-%:OK`(C, CATCH_ALL_catch(l)) -- wf_context: `%`(C) -- wf_catch: `%`(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]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6070,7 +6040,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) -- wf_context: `%`(C) -- wf_catch: `%`(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]) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -6104,7 +6073,6 @@ relation Defaultable: `|-%DEFAULTABLE`(valtype) rule _{t : valtype}: `|-%DEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) =/= ?()) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6211,7 +6179,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) @@ -6221,7 +6188,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instrtype: `%`(`%->_%%`_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*`}) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 @@ -6230,9 +6196,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- (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*`}))) @@ -6242,7 +6206,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)]))) - -- 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) @@ -6252,7 +6215,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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)])) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 @@ -6262,7 +6224,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)]))) - -- 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) @@ -6276,7 +6237,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)]))) - -- 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) @@ -6290,7 +6250,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 @@ -6300,7 +6259,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 @@ -6312,10 +6270,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:129.1-132.42 @@ -6337,7 +6293,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) @@ -6352,7 +6307,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) @@ -6369,10 +6323,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) @@ -6386,8 +6338,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) @@ -6426,9 +6376,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(`REF.FUNC`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:211.1-212.34 @@ -6495,7 +6443,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 @@ -6505,7 +6452,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`} @@ -6517,9 +6463,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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)) @@ -6531,9 +6475,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 @@ -6543,7 +6485,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 @@ -6553,7 +6494,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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)) @@ -6564,7 +6504,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 @@ -6574,9 +6513,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)))) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 @@ -6586,10 +6523,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 @@ -6599,7 +6534,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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)) @@ -6610,7 +6544,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:305.1-306.43 @@ -6627,7 +6560,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 @@ -6638,9 +6570,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) @@ -6651,9 +6581,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 @@ -6663,10 +6591,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:332.1-334.26 @@ -6692,7 +6618,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 @@ -6702,7 +6627,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) -- wf_localtype: `%`(`%%`_localtype(init, t)) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 @@ -6712,7 +6636,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) -- wf_localtype: `%`(`%%`_localtype(init, t)) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 @@ -6722,7 +6645,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 @@ -6732,7 +6654,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 @@ -6742,7 +6663,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(rt : reftype <: valtype)]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 @@ -6752,7 +6672,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (rt : reftype <: valtype)]), [], `%`_resulttype([]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 @@ -6762,7 +6681,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 @@ -6772,7 +6690,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 @@ -6782,7 +6699,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 @@ -6793,9 +6709,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6807,9 +6721,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6820,7 +6732,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_reftype: `%`(rt) -- wf_instr: `%`(`ELEM.DROP`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 @@ -6830,7 +6741,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([(at : addrtype <: valtype)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 @@ -6840,7 +6750,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(at : addrtype <: valtype)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 @@ -6850,7 +6759,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 @@ -6861,9 +6769,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 @@ -6873,9 +6779,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 @@ -6884,7 +6788,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(`DATA.DROP`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 @@ -6894,7 +6797,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(LOAD_instr(nt, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([(nt : numtype <: valtype)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -6905,7 +6807,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6916,7 +6817,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(STORE_instr(nt, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) (nt : numtype <: valtype)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -6927,7 +6827,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6938,7 +6837,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -6949,7 +6847,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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)) @@ -6960,7 +6857,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6971,7 +6867,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6982,7 +6877,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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))) @@ -6994,7 +6888,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VSTORE_instr(V128_vectype, x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([(at : addrtype <: valtype) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7005,7 +6898,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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))) @@ -7225,15 +7117,11 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- (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*`}))) - -- if (|`init*`| = |`t*`|) -- (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*`}))) -- 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*`| = |`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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:623.1-627.33 @@ -7274,7 +7162,6 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) rule _{t : valtype}: `|-%NONDEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) = ?()) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -7357,7 +7244,6 @@ relation Instr_const: `%|-%CONST`(context, instr) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_globaltype: `%`(`%%`_globaltype(?(), t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -7368,9 +7254,7 @@ relation Instr_const: `%|-%CONST`(context, instr) -- 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)) - -- 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)]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -7470,13 +7354,11 @@ 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|) -- 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 []}) -- 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*`})) @@ -7494,7 +7376,6 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) -- wf_context: `%`(C) -- wf_datamode: `%`(ACTIVE_datamode(x, expr)) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7530,7 +7411,6 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) -- wf_reftype: `%`(rt) -- wf_elemmode: `%`(ACTIVE_elemmode(x, expr)) -- wf_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, expr, (at : addrtype <: valtype)) @@ -7554,7 +7434,6 @@ relation Start_ok: `%|-%:OK`(context, start) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7574,7 +7453,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) -- wf_externtype: `%`(TAG_externtype(jt)) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7583,7 +7461,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) -- wf_externtype: `%`(GLOBAL_externtype(gt)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7592,7 +7469,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) -- wf_externtype: `%`(MEM_externtype(mt)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7601,7 +7477,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) -- wf_externtype: `%`(TABLE_externtype(tt)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7610,7 +7485,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) -- wf_externtype: `%`(FUNC_externtype((dt : deftype <: typeuse))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7702,24 +7576,15 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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*`})) -- 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 []}) @@ -12378,7 +12243,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.STRUCTS_store|) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 @@ -12387,7 +12251,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.ARRAYS_store|) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 @@ -12396,7 +12259,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 @@ -12406,7 +12268,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_exninst: `%`(exn) -- wf_ref: `%`(`REF.EXN_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), EXN_heaptype)) - -- if (a < |s.EXNS_store|) -- if (s.EXNS_store[a] = exn) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:57.1-58.35 @@ -12498,7 +12359,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) - -- if (a < |s.TAGS_store|) -- if (s.TAGS_store[a] = taginst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:109.1-111.34 @@ -12506,7 +12366,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) - -- if (a < |s.GLOBALS_store|) -- if (s.GLOBALS_store[a] = globalinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:113.1-115.28 @@ -12514,7 +12373,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) - -- if (a < |s.MEMS_store|) -- if (s.MEMS_store[a] = meminst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:117.1-119.32 @@ -12522,7 +12380,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) - -- if (a < |s.TABLES_store|) -- if (s.TABLES_store[a] = tableinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:121.1-123.30 @@ -12530,7 +12387,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) -- wf_store: `%`(s) -- wf_externtype: `%`(FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a] = funcinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:125.1-128.37 @@ -12682,7 +12538,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12692,7 +12547,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12701,7 +12555,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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*`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12710,7 +12563,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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*`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12743,7 +12595,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instr: `%`(BR_instr(l)) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12751,17 +12602,15 @@ relation Step_pure: `%~>%`(instr*, instr*) `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../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_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])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |l*{l <- `l*`}|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: @@ -12769,7 +12618,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) -- wf_instr: `%`(BR_instr(l')) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12883,7 +12731,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))))) @@ -13005,7 +12852,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) - -- if (|$unop_(nt, unop, c_1)| > 0) -- if (c <- $unop_(nt, unop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13023,7 +12869,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(CONST_instr(nt, c)) - -- if (|$binop_(nt, binop, c_1, c_2)| > 0) -- if (c <- $binop_(nt, binop, c_1, c_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13041,7 +12886,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13051,7 +12895,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13060,7 +12903,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13077,7 +12919,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13087,7 +12928,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13098,7 +12938,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VVTERNOP_instr(V128_vectype, vvternop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13107,7 +12946,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13116,7 +12954,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vunop_(sh, vunop, c_1)| > 0) -- if (c <- $vunop_(sh, vunop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13134,7 +12971,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vbinop_(sh, vbinop, c_1, c_2)| > 0) -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13154,7 +12990,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13176,8 +13011,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) -- 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*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13196,7 +13029,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if ($proj_num__0(i) =/= ?()) -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13205,7 +13037,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13243,7 +13074,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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))) - -- 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]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13253,9 +13083,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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))) - -- 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])))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13368,8 +13195,6 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- 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)) - -- 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) @@ -13379,8 +13204,6 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- (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)) - -- 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) @@ -13391,7 +13214,6 @@ relation `Step_read_before_table.fill-zero`: `%`(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((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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13408,7 +13230,6 @@ relation `Step_read_before_table.fill-succ`: `%`(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((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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13418,8 +13239,6 @@ relation `Step_read_before_table.copy-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13436,8 +13255,6 @@ relation `Step_read_before_table.copy-le`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13450,9 +13267,7 @@ relation `Step_read_before_table.copy-gt`: `%`(config) -- wf_instr: `%`(CONST_instr((at_2 : addrtype <: numtype), i_2)) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- if ($proj_num__0(i_1) =/= ?()) -- 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))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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: `%`(`TABLE.COPY`_instr(x, y)) @@ -13471,8 +13286,6 @@ relation `Step_read_before_table.copy-gt`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13482,8 +13295,6 @@ relation `Step_read_before_table.init-zero`: `%`(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((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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13500,8 +13311,6 @@ relation `Step_read_before_table.init-succ`: `%`(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((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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13511,7 +13320,6 @@ relation `Step_read_before_memory.fill-zero`: `%`(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((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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13528,7 +13336,6 @@ relation `Step_read_before_memory.fill-succ`: `%`(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((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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13538,8 +13345,6 @@ relation `Step_read_before_memory.copy-zero`: `%`(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((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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13556,8 +13361,6 @@ relation `Step_read_before_memory.copy-le`: `%`(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((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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13570,9 +13373,7 @@ relation `Step_read_before_memory.copy-gt`: `%`(config) -- 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)) - -- if ($proj_num__0(i_1) =/= ?()) -- 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))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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: `%`(`MEMORY.COPY`_instr(x_1, x_2)) @@ -13591,8 +13392,6 @@ relation `Step_read_before_memory.copy-gt`: `%`(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((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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13602,8 +13401,6 @@ relation `Step_read_before_memory.init-zero`: `%`(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((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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13620,8 +13417,6 @@ relation `Step_read_before_memory.init-succ`: `%`(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((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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13654,8 +13449,6 @@ relation `Step_read_before_array.fill-zero`: `%`(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) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13672,8 +13465,6 @@ relation `Step_read_before_array.fill-succ`: `%`(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) (val : val <: instr) CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(n))) `ARRAY.FILL`_instr(x)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13683,8 +13474,6 @@ relation `Step_read_before_array.copy-zero`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13692,8 +13481,6 @@ relation `Step_read_before_array.copy-zero`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13710,8 +13497,6 @@ relation `Step_read_before_array.copy-le`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13719,8 +13504,6 @@ relation `Step_read_before_array.copy-le`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13735,16 +13518,13 @@ 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)) - -- if ($proj_num__0(i_1) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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))) -- ~ `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)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13759,8 +13539,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)])) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13768,8 +13546,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)])) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13779,7 +13555,6 @@ relation `Step_read_before_array.init_elem-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_ELEM`_instr(x, 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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13787,8 +13562,6 @@ relation `Step_read_before_array.init_elem-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_ELEM`_instr(x, 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13805,7 +13578,6 @@ relation `Step_read_before_array.init_elem-succ`: `%`(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_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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13813,8 +13585,6 @@ relation `Step_read_before_array.init_elem-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13826,8 +13596,6 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13835,8 +13603,6 @@ 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)])) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13855,8 +13621,6 @@ relation `Step_read_before_array.init_data-num`: `%`(config) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13864,8 +13628,6 @@ 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)])) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13921,11 +13683,9 @@ 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)|) -- 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))) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13941,9 +13701,7 @@ relation Step_read: `%~>%`(config, instr*) -- 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*`})) - -- (if ($default_(t) =/= ?()))*{t <- `t*`} -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) - -- 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*`})) @@ -13952,11 +13710,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../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)|) -- 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))) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13984,7 +13740,6 @@ relation Step_read: `%~>%`(config, 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 (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*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14028,8 +13783,6 @@ relation Step_read: `%~>%`(config, instr*) -- (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)) - -- 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) @@ -14040,8 +13793,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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)) - -- 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) @@ -14092,15 +13843,13 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) ;; ../../../../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)]) - -- 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)])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.size`{z : state, x : idx, at : addrtype, n : n, lim : limits, rt : reftype}: @@ -14116,7 +13865,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14129,7 +13877,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) =/= ?()) -- 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)) @@ -14143,8 +13890,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14157,8 +13902,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) =/= ?()) -- 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)) @@ -14174,8 +13917,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) =/= ?()) -- 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))))) @@ -14192,8 +13933,6 @@ 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)]), [TRAP_instr]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14206,9 +13945,6 @@ 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) =/= ?()) -- 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)) @@ -14223,7 +13959,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14231,7 +13966,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14239,7 +13973,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14247,7 +13980,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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)))]) -- 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) =/= ?()) -- 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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14255,7 +13987,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14263,7 +13994,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14271,7 +14001,6 @@ 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)]), [TRAP_instr]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14281,7 +14010,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(K))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(K))), mk_lane__2_lane_(Jnn, $extend__(M, $jsizenn(Jnn), sx, j))))^K{j <- `j*`} - -- (if ($proj_num__0(i) =/= ?()))^(k rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14300,7 +14027,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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))) - -- 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))) @@ -14311,7 +14037,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14320,7 +14045,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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)) - -- 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)) @@ -14329,7 +14053,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14339,7 +14062,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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))) - -- 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))) @@ -14359,7 +14081,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14372,7 +14093,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) =/= ?()) -- 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)) @@ -14386,8 +14106,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14400,8 +14118,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) =/= ?()) -- 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)) @@ -14417,8 +14133,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) =/= ?()) -- 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))))) @@ -14435,8 +14149,6 @@ 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))) `MEMORY.INIT`_instr(x, y)]), [TRAP_instr]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14449,9 +14161,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) =/= ?()) -- 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($proj_byte_0($data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0]).0)))) @@ -14471,7 +14180,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])) @@ -14516,8 +14224,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14529,10 +14235,6 @@ 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)|) -- 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*`}))) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -14545,7 +14247,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($default_($unpack(zt)) =/= ?()) -- if (!($default_($unpack(zt))) = ?(val)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14553,7 +14254,6 @@ 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)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14562,7 +14262,6 @@ relation Step_read: `%~>%`(config, instr*) -- (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))) - -- if ($proj_num__0(i) =/= ?()) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : n]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14572,21 +14271,16 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- 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|) ;; ../../../../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{} -- (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))) -- 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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14600,17 +14294,11 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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) =/= ?()) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14624,7 +14312,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|)))) @@ -14639,8 +14326,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14653,7 +14338,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../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) =/= ?()) -- 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)) @@ -14680,8 +14364,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14689,8 +14371,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14703,8 +14383,6 @@ 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_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) =/= ?()) -- 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)) @@ -14719,14 +14397,11 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 ($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)))) ;; ../../../../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) =/= ?()) -- 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))))) @@ -14741,7 +14416,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14755,8 +14429,6 @@ 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_ELEM`_instr(x, y)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14764,7 +14436,6 @@ 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_ELEM`_instr(x, y)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14777,8 +14448,6 @@ 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_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) =/= ?()) -- 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)) @@ -14789,7 +14458,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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)) -- ~ `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 ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14803,8 +14471,6 @@ 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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14814,8 +14480,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14828,10 +14492,6 @@ 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) =/= ?()) -- 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)) @@ -14908,9 +14568,7 @@ relation Step: `%~>%`(config, config) -- 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([]))) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- 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 (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) @@ -14932,13 +14590,11 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- wf_config: `%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) (ref : ref <: instr) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:340.1-342.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) =/= ?()) -- 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), [])) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) @@ -14948,7 +14604,6 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_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|)))])) -- 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|)))])) - -- if ($growtable($table(z, x), n, ref) =/= ?()) -- if (ti = !($growtable($table(z, x), n, ref))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:356.1-357.87 @@ -14968,13 +14623,11 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- 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])) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:506.1-510.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) =/= ?()) -- 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*`}), [])) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) @@ -14984,16 +14637,13 @@ relation Step: `%~>%`(config, 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, [TRAP_instr])) -- 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])) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:517.1-521.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) =/= ?()) -- 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*`}), [])) - -- if ($proj_num__0(c) =/= ?()) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:523.1-526.63 @@ -15001,13 +14651,11 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [CONST_instr((at : addrtype <: numtype), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) -- 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])) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:528.1-531.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) =/= ?()) -- 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*`}), [])) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) @@ -15017,17 +14665,13 @@ relation Step: `%~>%`(config, 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, [TRAP_instr])) -- 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])) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:539.1-544.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) =/= ?()) -- 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*`}), [])) - -- 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)|) -- 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 (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) @@ -15038,7 +14682,6 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_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))))])) -- 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))))])) - -- if ($growmem($mem(z, x), n) =/= ?()) -- if (mi = !($growmem($mem(z, x), n))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:558.1-559.84 @@ -15059,7 +14702,6 @@ relation Step: `%~>%`(config, config) -- 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*`}))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) @@ -15074,8 +14716,6 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:724.1-727.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*`}|) -- 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))), [])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -15087,7 +14727,6 @@ relation Step: `%~>%`(config, config) -- 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))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) -- 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*`}})) @@ -15103,15 +14742,11 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) (val : val <: instr) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- 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])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:792.1-795.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) =/= ?()) -- 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))), [])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -15857,10 +15492,8 @@ 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 (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 []}) @@ -15871,8 +15504,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*`} @@ -15940,25 +15571,15 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) -- (wf_externtype: `%`(MEM_externtype(memtype)))*{memtype <- `memtype*`} -- (wf_externtype: `%`(TABLE_externtype(tabletype)))*{tabletype <- `tabletype*`} -- (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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -15971,7 +15592,6 @@ relation Frame_ok: `%|-%:%`(store, frame, context) -- 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 []}) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- if (|`lct*`| = |`val?*`|) -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16059,15 +15679,11 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- (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*`}))) - -- if (|`init*`| = |`t*`|) -- (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*`}))) -- 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*`| = |`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*`}))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:47.1-51.33 @@ -16175,7 +15791,6 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16197,10 +15812,8 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- 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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16221,21 +15834,16 @@ 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|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt)) -- 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)) ;; ../../../../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|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(), zt))) @@ -16244,8 +15852,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)) @@ -16290,19 +15896,12 @@ relation Store_ok: `|-%:OK`(store) -- (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*`}}) - -- 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*`} @@ -16382,8 +15981,6 @@ relation Extend_structinst: `%<=%`(structinst, structinst) -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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?*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16395,7 +15992,6 @@ relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (|`fv*`| = |`fv'*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16412,35 +16008,15 @@ relation Extend_store: `%<=%`(store, store) `%<=%`(s, s') -- wf_store: `%`(s) -- wf_store: `%`(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|){} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16534,7 +16110,6 @@ relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_globaltype: `%`(`%%`_globaltype(?(mut), t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(mut), t)) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:29.1-32.78 diff --git a/spectec/test-middlend/specification.exp/09-sub.il b/spectec/test-middlend/specification.exp/08-sub.il similarity index 98% rename from spectec/test-middlend/specification.exp/09-sub.il rename to spectec/test-middlend/specification.exp/08-sub.il index 32e024a639..e0171b45d7 100644 --- a/spectec/test-middlend/specification.exp/09-sub.il +++ b/spectec/test-middlend/specification.exp/08-sub.il @@ -1291,6 +1291,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 @@ -4511,7 +4512,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 @@ -5410,7 +5410,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) `%|-%:OK`(C, _IDX_typeuse(typeidx)) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 @@ -5419,7 +5418,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) -- wf_context: `%`(C) -- wf_subtype: `%`(st) -- wf_typeuse: `%`(REC_typeuse(i)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = st) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:114.1-116.35 @@ -5492,12 +5490,10 @@ relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) `%|-%:%`(C, SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype), OK_oktypenat(i)) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) - -- if (|`comptype'*`| = |`typeuse'**`|) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} -- (if $before(typeuse, i))*{typeuse <- `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'*`} @@ -5537,7 +5533,6 @@ relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) -- 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*`}))) - -- if (|`ft_1*`| = |`ft_2*`|) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:185.1-187.38 @@ -5571,7 +5566,6 @@ relation Deftype_sub: `%|-%<:%`(context, deftype, deftype) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) -- 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)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:9.1-9.104 @@ -5657,7 +5651,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0]), heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 @@ -5666,7 +5659,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_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])) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 @@ -5676,7 +5668,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(STRUCT_heaptype) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 @@ -5686,7 +5677,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(ARRAY_heaptype) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 @@ -5696,17 +5686,14 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- 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*`})))) - -- 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*`})))) ;; ../../../../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*`}|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:81.1-84.25 @@ -5815,7 +5802,6 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} -- (wf_valtype: `%`(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*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:150.1-150.119 @@ -5873,8 +5859,6 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) -- wf_instrtype: `%`(`%->_%%`_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*`} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5892,7 +5876,6 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5914,12 +5897,9 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) - -- if (|`comptype'*`| = |`yy**`|) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} -- if (|x*{x <- `x*`}| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} - -- if (|`comptype'*`| = |`x*`|) - -- (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'*`} @@ -6048,8 +6028,6 @@ 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*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec @@ -6180,7 +6158,6 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6191,10 +6168,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`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]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6203,10 +6177,7 @@ relation Catch_ok: `%|-%:OK`(context, catch) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`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]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6214,7 +6185,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) `%|-%:OK`(C, CATCH_ALL_catch(l)) -- wf_context: `%`(C) -- wf_catch: `%`(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]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6222,7 +6192,6 @@ relation Catch_ok: `%|-%:OK`(context, catch) `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) -- wf_context: `%`(C) -- wf_catch: `%`(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]) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -6256,7 +6225,6 @@ relation Defaultable: `|-%DEFAULTABLE`(valtype) rule _{t : valtype}: `|-%DEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) =/= ?()) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6363,7 +6331,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) @@ -6373,7 +6340,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instrtype: `%`(`%->_%%`_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*`}) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 @@ -6382,9 +6348,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- (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*`}))) @@ -6394,7 +6358,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)]))) - -- 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) @@ -6404,7 +6367,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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)])) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:96.1-102.34 @@ -6414,7 +6376,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_reftype: `%`(rt) -- wf_instr: `%`(BR_ON_CAST_instr(l, rt_1, rt_2)) -- wf_instrtype: `%`(`%->_%%`_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) @@ -6428,7 +6389,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_reftype: `%`(rt) -- 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)]))) - -- 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) @@ -6442,7 +6402,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 @@ -6452,7 +6411,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 @@ -6464,10 +6422,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:129.1-132.42 @@ -6489,7 +6445,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) @@ -6504,7 +6459,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) @@ -6521,10 +6475,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) @@ -6538,8 +6490,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) @@ -6578,9 +6528,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(`REF.FUNC`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:211.1-212.34 @@ -6647,7 +6595,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:250.1-253.48 @@ -6657,7 +6604,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`} @@ -6669,9 +6615,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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)) @@ -6683,9 +6627,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 @@ -6695,7 +6637,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:276.1-279.45 @@ -6705,7 +6646,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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)) @@ -6716,7 +6656,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:285.1-288.40 @@ -6726,9 +6665,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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?`}, $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?`}, $storagetype_reftype(rt)))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], rt) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:290.1-294.24 @@ -6738,10 +6675,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:296.1-299.41 @@ -6751,7 +6686,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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)) @@ -6762,7 +6696,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:305.1-306.43 @@ -6779,7 +6712,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], ARRAY_comptype(`%%`_fieldtype(?(MUT_mut), zt))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:312.1-316.40 @@ -6790,9 +6722,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) @@ -6803,9 +6733,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:323.1-327.24 @@ -6815,10 +6743,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:332.1-334.26 @@ -6844,7 +6770,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 @@ -6854,7 +6779,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) -- wf_localtype: `%`(`%%`_localtype(init, t)) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 @@ -6864,7 +6788,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) -- wf_localtype: `%`(`%%`_localtype(init, t)) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 @@ -6874,7 +6797,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 @@ -6884,7 +6806,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 @@ -6894,7 +6815,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 @@ -6904,7 +6824,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 @@ -6914,7 +6833,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 @@ -6924,7 +6842,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 @@ -6934,7 +6851,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 @@ -6945,9 +6861,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6959,9 +6873,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6972,7 +6884,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_reftype: `%`(rt) -- wf_instr: `%`(`ELEM.DROP`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 @@ -6982,7 +6893,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 @@ -6992,7 +6902,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 @@ -7002,7 +6911,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 @@ -7013,9 +6921,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 @@ -7025,9 +6931,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 @@ -7036,7 +6940,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(`DATA.DROP`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 @@ -7046,7 +6949,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(LOAD_instr(nt, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7057,7 +6959,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -7068,7 +6969,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(STORE_instr(nt, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7079,7 +6979,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -7090,7 +6989,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7101,7 +6999,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7112,7 +7009,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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) @@ -7123,7 +7019,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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) @@ -7134,7 +7029,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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))) @@ -7146,7 +7040,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VSTORE_instr(V128_vectype, x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7157,7 +7050,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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))) @@ -7377,15 +7269,11 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- (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*`}))) - -- if (|`init*`| = |`t*`|) -- (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*`}))) -- 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*`| = |`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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:623.1-627.33 @@ -7426,7 +7314,6 @@ relation Nondefaultable: `|-%NONDEFAULTABLE`(valtype) rule _{t : valtype}: `|-%NONDEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) -- if (!($default_(t)) = ?()) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -7509,7 +7396,6 @@ relation Instr_const: `%|-%CONST`(context, instr) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_globaltype: `%`(`%%`_globaltype(?(), t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -7520,9 +7406,7 @@ relation Instr_const: `%|-%CONST`(context, instr) -- 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)) - -- 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)]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -7622,13 +7506,11 @@ 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|) -- 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 []}) -- 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*`})) @@ -7646,7 +7528,6 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) -- wf_context: `%`(C) -- wf_datamode: `%`(ACTIVE_datamode(x, expr)) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7682,7 +7563,6 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) -- wf_reftype: `%`(rt) -- wf_elemmode: `%`(ACTIVE_elemmode(x, expr)) -- wf_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, expr, $valtype_addrtype(at)) @@ -7706,7 +7586,6 @@ relation Start_ok: `%|-%:OK`(context, start) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7726,7 +7605,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) -- wf_externtype: `%`(TAG_externtype(jt)) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7735,7 +7613,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) -- wf_externtype: `%`(GLOBAL_externtype(gt)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7744,7 +7621,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) -- wf_externtype: `%`(MEM_externtype(mt)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7753,7 +7629,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) -- wf_externtype: `%`(TABLE_externtype(tt)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7762,7 +7637,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(dt))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7854,24 +7728,15 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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*`})) -- 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 []}) @@ -12564,7 +12429,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.STRUCTS_store|) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 @@ -12573,7 +12437,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.ARRAYS_store|) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 @@ -12582,7 +12445,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 @@ -12592,7 +12454,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_exninst: `%`(exn) -- wf_ref: `%`(`REF.EXN_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), EXN_heaptype)) - -- if (a < |s.EXNS_store|) -- if (s.EXNS_store[a] = exn) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:57.1-58.35 @@ -12684,7 +12545,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) - -- if (a < |s.TAGS_store|) -- if (s.TAGS_store[a] = taginst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:109.1-111.34 @@ -12692,7 +12552,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) - -- if (a < |s.GLOBALS_store|) -- if (s.GLOBALS_store[a] = globalinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:113.1-115.28 @@ -12700,7 +12559,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) - -- if (a < |s.MEMS_store|) -- if (s.MEMS_store[a] = meminst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:117.1-119.32 @@ -12708,7 +12566,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) - -- if (a < |s.TABLES_store|) -- if (s.TABLES_store[a] = tableinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:121.1-123.30 @@ -12716,7 +12573,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) -- wf_store: `%`(s) -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a] = funcinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:125.1-128.37 @@ -12868,7 +12724,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12878,7 +12733,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12887,7 +12741,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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*`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12896,7 +12749,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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*`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12929,7 +12781,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instr: `%`(BR_instr(l)) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12937,17 +12788,15 @@ relation Step_pure: `%~>%`(instr*, instr*) `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../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_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])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |l*{l <- `l*`}|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: @@ -12955,7 +12804,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) -- wf_instr: `%`(BR_instr(l')) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13069,7 +12917,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))))) @@ -13191,7 +13038,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) - -- if (|$unop_(nt, unop, c_1)| > 0) -- if (c <- $unop_(nt, unop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13209,7 +13055,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(CONST_instr(nt, c)) - -- if (|$binop_(nt, binop, c_1, c_2)| > 0) -- if (c <- $binop_(nt, binop, c_1, c_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13227,7 +13072,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $testop_(nt, testop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13237,7 +13081,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13246,7 +13089,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13263,7 +13105,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13273,7 +13114,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13284,7 +13124,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VVTERNOP_instr(V128_vectype, vvternop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13293,7 +13132,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $inez_($vsize(V128_vectype), c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13302,7 +13140,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vunop_(sh, vunop, c_1)| > 0) -- if (c <- $vunop_(sh, vunop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13320,7 +13157,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VBINOP_instr(sh, vbinop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vbinop_(sh, vbinop, c_1, c_2)| > 0) -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13340,7 +13176,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VTERNOP_instr(sh, vternop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13362,8 +13197,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) -- 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*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13382,7 +13215,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(VSHIFTOP_instr(sh, vshiftop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if ($proj_num__0(i) =/= ?()) -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13391,7 +13223,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $vbitmaskop_(sh, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13429,7 +13260,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- 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))) - -- 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]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13439,9 +13269,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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($lanetype_packtype(pt), `%`_dim(M))) - -- 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])))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13554,8 +13381,6 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- 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)) - -- 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) @@ -13565,8 +13390,6 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- (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)) - -- 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) @@ -13577,7 +13400,6 @@ relation `Step_read_before_table.fill-zero`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13594,7 +13416,6 @@ relation `Step_read_before_table.fill-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13604,8 +13425,6 @@ relation `Step_read_before_table.copy-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13622,8 +13441,6 @@ relation `Step_read_before_table.copy-le`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13636,9 +13453,7 @@ relation `Step_read_before_table.copy-gt`: `%`(config) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- if ($proj_num__0(i_1) =/= ?()) -- 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))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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)) @@ -13657,8 +13472,6 @@ relation `Step_read_before_table.copy-gt`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13668,8 +13481,6 @@ relation `Step_read_before_table.init-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13686,8 +13497,6 @@ relation `Step_read_before_table.init-succ`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13697,7 +13506,6 @@ relation `Step_read_before_memory.fill-zero`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13714,7 +13522,6 @@ relation `Step_read_before_memory.fill-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13724,8 +13531,6 @@ relation `Step_read_before_memory.copy-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13742,8 +13547,6 @@ relation `Step_read_before_memory.copy-le`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13756,9 +13559,7 @@ relation `Step_read_before_memory.copy-gt`: `%`(config) -- 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)) - -- if ($proj_num__0(i_1) =/= ?()) -- 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))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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)) @@ -13777,8 +13578,6 @@ relation `Step_read_before_memory.copy-gt`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13788,8 +13587,6 @@ relation `Step_read_before_memory.init-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13806,8 +13603,6 @@ relation `Step_read_before_memory.init-succ`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13840,8 +13635,6 @@ relation `Step_read_before_array.fill-zero`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13858,8 +13651,6 @@ relation `Step_read_before_array.fill-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13869,8 +13660,6 @@ relation `Step_read_before_array.copy-zero`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13878,8 +13667,6 @@ relation `Step_read_before_array.copy-zero`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13896,8 +13683,6 @@ relation `Step_read_before_array.copy-le`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13905,8 +13690,6 @@ relation `Step_read_before_array.copy-le`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13921,16 +13704,13 @@ 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)) - -- if ($proj_num__0(i_1) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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))) -- ~ `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)))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13945,8 +13725,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)])) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13954,8 +13732,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)])) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13965,7 +13741,6 @@ relation `Step_read_before_array.init_elem-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_ELEM`_instr(x, 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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13973,8 +13748,6 @@ relation `Step_read_before_array.init_elem-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_ELEM`_instr(x, 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13991,7 +13764,6 @@ relation `Step_read_before_array.init_elem-succ`: `%`(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_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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13999,8 +13771,6 @@ relation `Step_read_before_array.init_elem-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14012,8 +13782,6 @@ relation `Step_read_before_array.init_data-zero`: `%`(config) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14021,8 +13789,6 @@ 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)])) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14041,8 +13807,6 @@ relation `Step_read_before_array.init_data-num`: `%`(config) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14050,8 +13814,6 @@ 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)])) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14107,11 +13869,9 @@ 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)|) -- 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))) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14127,9 +13887,7 @@ relation Step_read: `%~>%`(config, instr*) -- 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*`})) - -- (if ($default_(t) =/= ?()))*{t <- `t*`} -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) - -- 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*`})) @@ -14138,11 +13896,9 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../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)|) -- 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))) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14170,7 +13926,6 @@ relation Step_read: `%~>%`(config, 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 (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*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14214,8 +13969,6 @@ relation Step_read: `%~>%`(config, instr*) -- (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)) - -- 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) @@ -14226,8 +13979,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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)) - -- 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) @@ -14278,15 +14029,13 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) ;; ../../../../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($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($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.size`{z : state, x : idx, at : addrtype, n : n, lim : limits, rt : reftype}: @@ -14302,7 +14051,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14315,7 +14063,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) =/= ?()) -- 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)) @@ -14329,8 +14076,6 @@ relation Step_read: `%~>%`(config, 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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14343,8 +14088,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) =/= ?()) -- 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)) @@ -14360,8 +14103,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) =/= ?()) -- 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))))) -- 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))))) @@ -14378,8 +14119,6 @@ relation Step_read: `%~>%`(config, 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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14392,9 +14131,6 @@ 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) =/= ?()) -- 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)) @@ -14409,7 +14145,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14417,7 +14152,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14425,7 +14159,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14433,7 +14166,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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)))]) -- 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)))) - -- 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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14441,7 +14173,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14449,7 +14180,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14457,7 +14187,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14467,7 +14196,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(K))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(K))), mk_lane__2_lane_(Jnn, $extend__(M, $jsizenn(Jnn), sx, j))))^K{j <- `j*`} - -- (if ($proj_num__0(i) =/= ?()))^(k rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14486,7 +14213,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- 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))) - -- 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))) @@ -14497,7 +14223,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14506,7 +14231,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_uN: `%%`(N, 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)) - -- 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)) @@ -14515,7 +14239,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14525,7 +14248,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- 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))) - -- 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))) @@ -14545,7 +14267,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14558,7 +14279,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) =/= ?()) -- 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)) @@ -14572,8 +14292,6 @@ relation Step_read: `%~>%`(config, 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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14586,8 +14304,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) =/= ?()) -- 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)) @@ -14603,8 +14319,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) =/= ?()) -- 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))))) @@ -14621,8 +14335,6 @@ relation Step_read: `%~>%`(config, 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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14635,9 +14347,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) =/= ?()) -- 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)))) @@ -14657,7 +14366,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])) @@ -14702,8 +14410,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14715,10 +14421,6 @@ 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)|) -- 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*`}))) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -14731,7 +14433,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($default_($unpack(zt)) =/= ?()) -- if (!($default_($unpack(zt))) = ?(val)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14739,7 +14440,6 @@ 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)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14748,7 +14448,6 @@ relation Step_read: `%~>%`(config, instr*) -- (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))) - -- if ($proj_num__0(i) =/= ?()) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : n]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14758,21 +14457,16 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- 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|) ;; ../../../../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{} -- (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))) -- 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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14786,17 +14480,11 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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) =/= ?()) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -14810,7 +14498,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|)))) @@ -14825,8 +14512,6 @@ relation Step_read: `%~>%`(config, 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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14839,7 +14524,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../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) =/= ?()) -- 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)) @@ -14866,8 +14550,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14875,8 +14557,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14889,8 +14569,6 @@ 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_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) =/= ?()) -- 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)) @@ -14905,14 +14583,11 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 ($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)))) ;; ../../../../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) =/= ?()) -- 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))))) @@ -14927,7 +14602,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14941,8 +14615,6 @@ 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_ELEM`_instr(x, y)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14950,7 +14622,6 @@ 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_ELEM`_instr(x, y)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14963,8 +14634,6 @@ 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) $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) =/= ?()) -- 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)) @@ -14975,7 +14644,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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)) -- ~ `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 ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14989,8 +14657,6 @@ 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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -15000,8 +14666,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -15014,10 +14678,6 @@ 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) =/= ?()) -- 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)) @@ -15094,9 +14754,7 @@ relation Step: `%~>%`(config, config) -- 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([]))) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- 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 (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) @@ -15118,13 +14776,11 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:340.1-342.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) =/= ?()) -- 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), [])) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) @@ -15134,7 +14790,6 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_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|)))])) -- 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|)))])) - -- if ($growtable($table(z, x), n, ref) =/= ?()) -- if (ti = !($growtable($table(z, x), n, ref))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:356.1-357.87 @@ -15154,13 +14809,11 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(z, [TRAP_instr])) -- 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) =/= ?()) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:506.1-510.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) =/= ?()) -- 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 (b*{b <- `b*`} = $nbytes_(nt, c)) @@ -15170,16 +14823,13 @@ relation Step: `%~>%`(config, 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)]), `%;%`_config(z, [TRAP_instr])) -- 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])) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:517.1-521.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) =/= ?()) -- 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(c) =/= ?()) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:523.1-526.63 @@ -15187,13 +14837,11 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(z, [TRAP_instr])) -- 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) =/= ?()) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:528.1-531.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) =/= ?()) -- 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 (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) @@ -15203,17 +14851,13 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_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])) -- 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])) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:539.1-544.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) =/= ?()) -- 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_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_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) -- if (N = $jsize(Jnn)) -- if ((M : nat <:> rat) = ((128 : nat <:> rat) / (N : nat <:> rat))) @@ -15224,7 +14868,6 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_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))))])) -- 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))))])) - -- if ($growmem($mem(z, x), n) =/= ?()) -- if (mi = !($growmem($mem(z, x), n))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:558.1-559.84 @@ -15245,7 +14888,6 @@ relation Step: `%~>%`(config, config) -- 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*`}))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) -- if (a = |$structinst(z)|) @@ -15260,8 +14902,6 @@ relation Step: `%~>%`(config, config) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:724.1-727.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*`}|) -- 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))), [])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) @@ -15273,7 +14913,6 @@ relation Step: `%~>%`(config, config) -- 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))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) -- 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*`}})) @@ -15289,15 +14928,11 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- 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])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:792.1-795.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) =/= ?()) -- 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))), [])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) @@ -16076,10 +15711,8 @@ 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 (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 []}) @@ -16090,8 +15723,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*`} @@ -16159,25 +15790,15 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) -- (wf_externtype: `%`(MEM_externtype(memtype)))*{memtype <- `memtype*`} -- (wf_externtype: `%`(TABLE_externtype(tabletype)))*{tabletype <- `tabletype*`} -- (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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16190,7 +15811,6 @@ relation Frame_ok: `%|-%:%`(store, frame, context) -- 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 []}) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- if (|`lct*`| = |`val?*`|) -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16278,15 +15898,11 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- (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*`}))) - -- if (|`init*`| = |`t*`|) -- (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*`}))) -- 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*`| = |`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*`}))) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:47.1-51.33 @@ -16394,7 +16010,6 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16416,10 +16031,8 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- 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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16440,21 +16053,16 @@ 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|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt)) -- 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)) ;; ../../../../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|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(), zt))) @@ -16463,8 +16071,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)) @@ -16509,19 +16115,12 @@ relation Store_ok: `|-%:OK`(store) -- (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*`}}) - -- 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*`} @@ -16601,8 +16200,6 @@ relation Extend_structinst: `%<=%`(structinst, structinst) -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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?*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16614,7 +16211,6 @@ relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (|`fv*`| = |`fv'*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16631,35 +16227,15 @@ relation Extend_store: `%<=%`(store, store) `%<=%`(s, s') -- wf_store: `%`(s) -- wf_store: `%`(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|){} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16753,7 +16329,6 @@ relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_globaltype: `%`(`%%`_globaltype(?(mut), t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(mut), t)) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:29.1-32.78 diff --git a/spectec/test-middlend/specification.exp/10-alias-demut.il b/spectec/test-middlend/specification.exp/09-definition-to-relation.il similarity index 77% rename from spectec/test-middlend/specification.exp/10-alias-demut.il rename to spectec/test-middlend/specification.exp/09-definition-to-relation.il index 4634e284d9..0ed7062260 100644 --- a/spectec/test-middlend/specification.exp/10-alias-demut.il +++ b/spectec/test-middlend/specification.exp/09-definition-to-relation.il @@ -244,32 +244,68 @@ syntax i64 = iN syntax i128 = iN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $signif(N : N) : nat? +relation fun_signif_before_fun_signif_case_2: `%`(N) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $signif(32) = ?(23) + rule fun_signif_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $signif(64) = ?(52) - def $signif{x0 : N}(x0) = ?() - -- otherwise + rule fun_signif_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $expon(N : N) : nat? +relation fun_signif: `%%`(N, nat?) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $expon(32) = ?(8) + rule fun_signif_case_0: + `%%`(32, ?(23)) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $expon(64) = ?(11) - def $expon{x0 : N}(x0) = ?() - -- otherwise + rule fun_signif_case_1: + `%%`(64, ?(52)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_signif_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_signif_before_fun_signif_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_expon_before_fun_expon_case_2: `%`(N) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_expon: `%%`(N, nat?) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_0: + `%%`(32, ?(8)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_1: + `%%`(64, ?(11)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_expon_before_fun_expon_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $M(N : N) : nat +relation fun_M: `%%`(N, nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $M{N : nat}(N) = !($signif(N)) + rule fun_M_case_0{N : nat, var_0 : nat?}: + `%%`(N, !(var_0)) + -- fun_signif: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $E(N : N) : nat +relation fun_E: `%%`(N, nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $E{N : nat}(N) = !($expon(N)) + rule fun_E_case_0{N : nat, var_0 : nat?}: + `%%`(N, !(var_0)) + -- fun_expon: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax exp = int @@ -284,23 +320,28 @@ syntax fNmag = ;; ../../../../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}: + rule fNmag_case_0{N : N, m : m, exp : exp, var_1 : nat, var_0 : nat}: `%%`(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))))) + -- if ((m < (2 ^ var_0)) /\ ((((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= exp) /\ (exp <= (((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) + -- fun_E: `%%`(N, var_1) + -- fun_M: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_1{N : N, exp : exp, m : m}: + rule fNmag_case_1{N : N, exp : exp, m : m, var_1 : nat, var_0 : nat}: `%%`(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)) + -- if ((m < (2 ^ var_0)) /\ (((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = exp)) + -- fun_E: `%%`(N, var_1) + -- fun_M: `%%`(N, var_0) ;; ../../../../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}: + rule fNmag_case_3{N : N, m : m, var_0 : nat}: `%%`(N, NAN_fNmag(m)) - -- if ((1 <= m) /\ (m < (2 ^ $M(N)))) + -- if ((1 <= m) /\ (m < (2 ^ var_0))) + -- fun_M: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax fN = @@ -326,27 +367,32 @@ syntax f32 = fN syntax f64 = fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $fzero(N : N) : fN +relation fun_fzero: `%%`(N, fN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) + rule fun_fzero_case_0{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 +relation fun_fnat: `%%%`(N, 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))) + rule fun_fnat_case_0{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 +relation fun_fone: `%%`(N, fN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) + rule fun_fone_case_0{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 +relation fun_canon_: `%%`(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)) + rule fun_canon__case_0{N : nat, var_0 : nat?}: + `%%`(N, (2 ^ (((!(var_0) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + -- fun_signif: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax vN = uN @@ -381,45 +427,62 @@ 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, b : byte}([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, b : byte}: + `%%`([ch], [b]) -- wf_byte: `%`(b) -- wf_byte: `%`(`%`_byte($proj_char_0(ch).0)) -- if ($proj_char_0(ch).0 < 128) -- if (`%`_byte($proj_char_0(ch).0) = b) - ;; ../../../../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]) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(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))) - ;; ../../../../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)) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(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))) - ;; ../../../../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)) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_4, var_2) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(b_3) -- wf_byte: `%`(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))) + -- 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)) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -434,10 +497,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 @@ -610,97 +674,128 @@ relation wf_free: `%`(free) -- (wf_uN: `%%`(32, var_9))*{var_9 <- var_9} ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_opt(free?) : free +relation fun_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 []} + rule fun_free_opt_case_0: + `%%`(?(), {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 + rule fun_free_opt_case_1{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 []} +;; ../../../../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 []}) -- 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 + 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 -def $free_typeidx(typeidx : typeidx) : free +relation fun_free_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 []} + rule fun_free_typeidx_case_0{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 +relation fun_free_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 []} + rule fun_free_funcidx_case_0{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 +relation fun_free_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 []} + rule fun_free_globalidx_case_0{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 +relation fun_free_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 []} + rule fun_free_tableidx_case_0{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 +relation fun_free_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 []} + rule fun_free_memidx_case_0{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 +relation fun_free_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 []} + rule fun_free_elemidx_case_0{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 +relation fun_free_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 []} + rule fun_free_dataidx_case_0{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 +relation fun_free_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 []} + rule fun_free_localidx_case_0{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 +relation fun_free_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 []} + rule fun_free_labelidx_case_0{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 +relation fun_free_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]} + rule fun_free_tagidx_case_0{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 +relation fun_free_externidx: `%%`(externidx, free) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{funcidx : uN}(FUNC_externidx(funcidx)) = $free_funcidx(funcidx) + rule fun_free_externidx_case_0{funcidx : uN, var_0 : free}: + `%%`(FUNC_externidx(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{globalidx : uN}(GLOBAL_externidx(globalidx)) = $free_globalidx(globalidx) + rule fun_free_externidx_case_1{globalidx : uN, var_0 : free}: + `%%`(GLOBAL_externidx(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{tableidx : uN}(TABLE_externidx(tableidx)) = $free_tableidx(tableidx) + rule fun_free_externidx_case_2{tableidx : uN, var_0 : free}: + `%%`(TABLE_externidx(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{memidx : uN}(MEM_externidx(memidx)) = $free_memidx(memidx) + rule fun_free_externidx_case_3{memidx : uN, var_0 : free}: + `%%`(MEM_externidx(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) + rule fun_free_externidx_case_4{tagidx : uN, var_0 : free}: + `%%`(TAG_externidx(tagidx), var_0) + -- fun_free_tagidx: `%%`(tagidx, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = @@ -814,6 +909,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) @@ -822,7 +920,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 = @@ -833,9 +931,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 @@ -1151,75 +1246,87 @@ syntax Cnn = | V128 ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $ANYREF : reftype +relation fun_ANYREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) + rule fun_ANYREF_case_0: + `%`(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 +relation fun_EQREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) + rule fun_EQREF_case_0: + `%`(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 +relation fun_I31REF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) + rule fun_I31REF_case_0: + `%`(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 +relation fun_STRUCTREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) + rule fun_STRUCTREF_case_0: + `%`(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 +relation fun_ARRAYREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) + rule fun_ARRAYREF_case_0: + `%`(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 +relation fun_FUNCREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) + rule fun_FUNCREF_case_0: + `%`(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 +relation fun_EXNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) + rule fun_EXNREF_case_0: + `%`(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 +relation fun_EXTERNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) + rule fun_EXTERNREF_case_0: + `%`(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 +relation fun_NULLREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) + rule fun_NULLREF_case_0: + `%`(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 +relation fun_NULLFUNCREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) + rule fun_NULLFUNCREF_case_0: + `%`(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 +relation fun_NULLEXNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) + rule fun_NULLEXNREF_case_0: + `%`(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 +relation fun_NULLEXTERNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) + rule fun_NULLEXTERNREF_case_0: + `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1291,6 +1398,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 @@ -1384,35 +1492,95 @@ relation wf_moduletype: `%`(moduletype) -- (wf_externtype: `%`(`externtype*_0`))*{`externtype*_0` <- `externtype*_0`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $IN(N : N) : Inn? +relation fun_IN_before_fun_IN_case_2: `%`(N) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $IN(32) = ?(I32_Inn) + rule fun_IN_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $IN(64) = ?(I64_Inn) - def $IN{x0 : N}(x0) = ?() - -- otherwise + rule fun_IN_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $FN(N : N) : Fnn? +relation fun_IN: `%%`(N, Inn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FN(32) = ?(F32_Fnn) + rule fun_IN_case_0: + `%%`(32, ?(I32_Inn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FN(64) = ?(F64_Fnn) - def $FN{x0 : N}(x0) = ?() - -- otherwise + rule fun_IN_case_1: + `%%`(64, ?(I64_Inn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_IN_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_IN_before_fun_IN_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_FN_before_fun_FN_case_2: `%`(N) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $JN(N : N) : Jnn? +relation fun_FN: `%%`(N, Fnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(8) = ?(I8_Jnn) + rule fun_FN_case_0: + `%%`(32, ?(F32_Fnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(16) = ?(I16_Jnn) + rule fun_FN_case_1: + `%%`(64, ?(F64_Fnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(32) = ?(I32_Jnn) + rule fun_FN_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_FN_before_fun_FN_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_JN_before_fun_JN_case_4: `%`(N) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(64) = ?(I64_Jnn) - def $JN{x0 : N}(x0) = ?() - -- otherwise + rule fun_JN_case_3: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_2: + `%`(32) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_1: + `%`(16) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_0: + `%`(8) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_JN: `%%`(N, Jnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_0: + `%%`(8, ?(I8_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_1: + `%%`(16, ?(I16_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_2: + `%%`(32, ?(I32_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_3: + `%%`(64, ?(I64_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_4{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_JN_before_fun_JN_case_4: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $size(numtype : numtype) : nat @@ -1453,23 +1621,69 @@ def $lsize(lanetype : lanetype) : nat def $lsize(I16_lanetype) = $psize(I16_packtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $zsize(storagetype : storagetype) : nat? +relation fun_zsize_before_fun_zsize_case_7: `%`(storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(I32_storagetype) = ?($size(I32_numtype)) + rule fun_zsize_case_6: + `%`(I16_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(I64_storagetype) = ?($size(I64_numtype)) + rule fun_zsize_case_5: + `%`(I8_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(F32_storagetype) = ?($size(F32_numtype)) + rule fun_zsize_case_4: + `%`(V128_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(F64_storagetype) = ?($size(F64_numtype)) + rule fun_zsize_case_3: + `%`(F64_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(V128_storagetype) = ?($vsize(V128_vectype)) + rule fun_zsize_case_2: + `%`(F32_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(I8_storagetype) = ?($psize(I8_packtype)) + rule fun_zsize_case_1: + `%`(I64_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(I16_storagetype) = ?($psize(I16_packtype)) - def $zsize{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_zsize_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_zsize: `%%`(storagetype, nat?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_0: + `%%`(I32_storagetype, ?($size(I32_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_1: + `%%`(I64_storagetype, ?($size(I64_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_2: + `%%`(F32_storagetype, ?($size(F32_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_3: + `%%`(F64_storagetype, ?($size(F64_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_4: + `%%`(V128_storagetype, ?($vsize(V128_vectype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_5: + `%%`(I8_storagetype, ?($psize(I8_packtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_6: + `%%`(I16_storagetype, ?($psize(I16_packtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_7{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_zsize_before_fun_zsize_case_7: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $isize(Inn : Inn) : nat @@ -1487,31 +1701,69 @@ def $fsize(Fnn : Fnn) : nat def $fsize{Fnn : Fnn}(Fnn) = $size($numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_isize(nat : nat) : Inn? +relation fun_inv_isize_before_fun_inv_isize_case_2: `%`(nat) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_isize(32) = ?(I32_Inn) + rule fun_inv_isize_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_isize(64) = ?(I64_Inn) - def $inv_isize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_inv_isize_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_jsize(nat : nat) : Jnn? +relation fun_inv_isize: `%%`(nat, Inn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize(8) = ?(I8_Jnn) + rule fun_inv_isize_case_0: + `%%`(32, ?(I32_Inn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize(16) = ?(I16_Jnn) + rule fun_inv_isize_case_1: + `%%`(64, ?(I64_Inn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize{n : nat}(n) = $Jnn_addrtype(iter_val#1)?{iter_val#1 <- $inv_isize(n)} + rule fun_inv_isize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_inv_isize_before_fun_inv_isize_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_fsize(nat : nat) : Fnn? +relation fun_inv_jsize: `%%`(nat, Jnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_fsize(32) = ?(F32_Fnn) + rule fun_inv_jsize_case_0: + `%%`(8, ?(I8_Jnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_fsize(64) = ?(F64_Fnn) - def $inv_fsize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_inv_jsize_case_1: + `%%`(16, ?(I16_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_jsize_case_2{n : nat, var_0 : Inn?}: + `%%`(n, $Jnn_addrtype(iter_val#1)?{iter_val#1 <- var_0}) + -- fun_inv_isize: `%%`(n, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(nat) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_fsize: `%%`(nat, Fnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_0: + `%%`(32, ?(F32_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_1: + `%%`(64, ?(F64_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $sizenn(numtype : numtype) : nat @@ -1559,9 +1811,11 @@ def $jsizenn(Jnn : Jnn) : nat def $jsizenn{Jnn : Jnn}(Jnn) = $lsize($lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_jsizenn(nat : nat) : Jnn? +relation fun_inv_jsizenn: `%%`(nat, Jnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsizenn{n : nat}(n) = $inv_jsize(n) + rule fun_inv_jsizenn_case_0{n : nat, var_0 : Jnn?}: + `%%`(n, var_0) + -- fun_inv_jsize: `%%`(n, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lunpack(lanetype : lanetype) : numtype @@ -1579,82 +1833,231 @@ def $lunpack(lanetype : lanetype) : numtype def $lunpack(I16_lanetype) = I32_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $unpack(storagetype : storagetype) : valtype +relation fun_unpack: `%%`(storagetype, valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(BOT_storagetype) = BOT_valtype + rule fun_unpack_case_0: + `%%`(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) + rule fun_unpack_case_1{`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 + rule fun_unpack_case_2: + `%%`(V128_storagetype, V128_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(F64_storagetype) = F64_valtype + rule fun_unpack_case_3: + `%%`(F64_storagetype, F64_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(F32_storagetype) = F32_valtype + rule fun_unpack_case_4: + `%%`(F32_storagetype, F32_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(I64_storagetype) = I64_valtype + rule fun_unpack_case_5: + `%%`(I64_storagetype, I64_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(I32_storagetype) = I32_valtype + rule fun_unpack_case_6: + `%%`(I32_storagetype, I32_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(I8_storagetype) = I32_valtype + rule fun_unpack_case_7: + `%%`(I8_storagetype, I32_valtype) -- wf_valtype: `%`(I32_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(I16_storagetype) = I32_valtype + rule fun_unpack_case_8: + `%%`(I16_storagetype, I32_valtype) -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $nunpack(storagetype : storagetype) : numtype? +relation fun_nunpack_before_fun_nunpack_case_6: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_5: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_4: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_nunpack: `%%`(storagetype, numtype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_0: + `%%`(I32_storagetype, ?(I32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(I32_storagetype) = ?(I32_numtype) + rule fun_nunpack_case_1: + `%%`(I64_storagetype, ?(I64_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(I64_storagetype) = ?(I64_numtype) + rule fun_nunpack_case_2: + `%%`(F32_storagetype, ?(F32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(F32_storagetype) = ?(F32_numtype) + rule fun_nunpack_case_3: + `%%`(F64_storagetype, ?(F64_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(F64_storagetype) = ?(F64_numtype) + rule fun_nunpack_case_4: + `%%`(I8_storagetype, ?(I32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(I8_storagetype) = ?(I32_numtype) + rule fun_nunpack_case_5: + `%%`(I16_storagetype, ?(I32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(I16_storagetype) = ?(I32_numtype) - def $nunpack{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_nunpack_case_6{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_nunpack_before_fun_nunpack_case_6: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $vunpack(storagetype : storagetype) : vectype? +relation fun_vunpack_before_fun_vunpack_case_1: `%`(storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $vunpack(V128_storagetype) = ?(V128_vectype) - def $vunpack{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_vunpack_case_0: + `%`(V128_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_vunpack: `%%`(storagetype, vectype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_vunpack_case_0: + `%%`(V128_storagetype, ?(V128_vectype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_vunpack_case_1{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_vunpack_before_fun_vunpack_case_1: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $cunpack(storagetype : storagetype) : consttype? +relation fun_cunpack_before_fun_cunpack_case_13: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_12: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_11: + `%`(I8_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I32_storagetype) = ?(I32_consttype) + rule fun_cunpack_case_10: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_9: + `%`(F32_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I64_storagetype) = ?(I64_consttype) + rule fun_cunpack_case_8: + `%`(I64_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(F32_storagetype) = ?(F32_consttype) + rule fun_cunpack_case_7: + `%`(I32_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(F64_storagetype) = ?(F64_consttype) + rule fun_cunpack_case_6: + `%`(I16_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(V128_storagetype) = ?(V128_consttype) + rule fun_cunpack_case_5: + `%`(I8_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I8_storagetype) = ?(I32_consttype) + rule fun_cunpack_case_4: + `%`(V128_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I16_storagetype) = ?(I32_consttype) + rule fun_cunpack_case_3: + `%`(F64_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I32_storagetype) = ?($consttype_numtype($lunpack(I32_lanetype))) + rule fun_cunpack_case_2: + `%`(F32_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I64_storagetype) = ?($consttype_numtype($lunpack(I64_lanetype))) + rule fun_cunpack_case_1: + `%`(I64_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(F32_storagetype) = ?($consttype_numtype($lunpack(F32_lanetype))) + rule fun_cunpack_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_cunpack: `%%`(storagetype, consttype?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(F64_storagetype) = ?($consttype_numtype($lunpack(F64_lanetype))) + rule fun_cunpack_case_0: + `%%`(I32_storagetype, ?(I32_consttype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I8_storagetype) = ?($consttype_numtype($lunpack(I8_lanetype))) + rule fun_cunpack_case_1: + `%%`(I64_storagetype, ?(I64_consttype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I16_storagetype) = ?($consttype_numtype($lunpack(I16_lanetype))) - def $cunpack{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_cunpack_case_2: + `%%`(F32_storagetype, ?(F32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_3: + `%%`(F64_storagetype, ?(F64_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_4: + `%%`(V128_storagetype, ?(V128_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_5: + `%%`(I8_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_6: + `%%`(I16_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_7: + `%%`(I32_storagetype, ?($consttype_numtype($lunpack(I32_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_8: + `%%`(I64_storagetype, ?($consttype_numtype($lunpack(I64_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_9: + `%%`(F32_storagetype, ?($consttype_numtype($lunpack(F32_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_10: + `%%`(F64_storagetype, ?($consttype_numtype($lunpack(F64_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_11: + `%%`(I8_storagetype, ?($consttype_numtype($lunpack(I8_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_12: + `%%`(I16_storagetype, ?($consttype_numtype($lunpack(I16_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_13{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_cunpack_before_fun_cunpack_case_13: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype @@ -1662,20 +2065,33 @@ def $minat(addrtype : addrtype, addrtype : addrtype) : addrtype 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 +relation fun_diffrt: `%%%`(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) + rule fun_diffrt_case_0{`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) + rule fun_diffrt_case_1{`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 -def $as_deftype(typeuse : typeuse) : deftype? +relation fun_as_deftype_before_fun_as_deftype_case_1: `%`(typeuse) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $as_deftype{rectype : rectype, n : n}(_DEF_typeuse(rectype, n)) = ?(_DEF_deftype(rectype, n)) - def $as_deftype{x0 : typeuse}(x0) = ?() - -- otherwise + rule fun_as_deftype_case_0{rectype : rectype, n : n}: + `%`(_DEF_typeuse(rectype, n)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_as_deftype: `%%`(typeuse, deftype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_0{rectype : rectype, n : n}: + `%%`(_DEF_typeuse(rectype, n), ?(_DEF_deftype(rectype, n))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_1{x0 : typeuse}: + `%%`(x0, ?()) + -- ~ fun_as_deftype_before_fun_as_deftype_case_1: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { @@ -1742,36 +2158,82 @@ def $funcsxt(externtype*) : deftype* 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 +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.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: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: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#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*, `tv'*` : typevar*, `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'*`})) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation fun_minus_recs_before_fun_minus_recs_case_3: `%%`(typevar*, typeuse*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%`([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} -- wf_typevar: `%`(_IDX_typevar(x)) - -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !($minus_recs(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}))) - def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() - -- otherwise + -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_0: + `%%`([], []) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_0: + `%%%`([], [], ?(([], []))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}, var_0) + -- fun_minus_recs: `%%%`(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, 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'*`}))) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) + -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} + -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} + -- wf_typevar: `%`(_IDX_typevar(x)) + -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_3{x0 : typevar*, x1 : typeuse*}: + `%%%`(x0, x1, ?()) + -- ~ fun_minus_recs_before_fun_minus_recs_case_3: `%%`(x0, x1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1792,107 +2254,192 @@ 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 +;; ../../../../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_1 : heaptype, 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#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, var_1) + -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) + +;; ../../../../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#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:345.6-345.20 + rule fun_subst_valtype_case_1{`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:345.6-345.20 + rule fun_subst_valtype_case_2{`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:345.6-345.20 + rule fun_subst_valtype_case_3{`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:345.6-345.20 + rule fun_subst_valtype_case_4{`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: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#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}, $valtype_reftype(var_0)) + -- fun_subst_reftype: `%%%%`(REF_reftype(`null?`, heaptype), tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `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#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `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{`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'#4*{tu'#4 <- `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'#5, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`})*{tu'#5 <- `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*, `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*`})) +;; ../../../../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#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(BOT_valtype, tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `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#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(REF_valtype(`null?`, heaptype), tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `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#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(V128_valtype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `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#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F64_valtype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `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#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F32_valtype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `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#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I64_valtype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `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#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I32_valtype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `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#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:348.6-348.24 + rule fun_subst_storagetype_case_8{`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.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_1 : storagetype, var_0 : storagetype}: + `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_storagetype: `%%%%`(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, var_1) + -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) + +;; ../../../../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_1*` : fieldtype*, `var_0*` : fieldtype*}: + `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- (fun_subst_fieldtype: `%%%%`(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, var_1))*{var_1 <- `var_1*`, ft#2 <- `ft*`} + -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) + + ;; ../../../../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_1 : fieldtype, var_0 : fieldtype}: + `%%%%`(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, ARRAY_comptype(var_0)) + -- fun_subst_fieldtype: `%%%%`(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}, var_1) + -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_comptype: `%`(ARRAY_comptype(var_1)) + + ;; ../../../../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_3*` : valtype*, `var_2*` : valtype*, `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#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- (fun_subst_valtype: `%%%%`(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_3))*{var_3 <- `var_3*`, t_2#2 <- `t_2*`} + -- (fun_subst_valtype: `%%%%`(t_1#2, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}, var_2))*{var_2 <- `var_2*`, t_1#2 <- `t_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*`} + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) + +;; ../../../../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_3 : comptype, `var_2*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: + `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#4*{tu'#4 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- fun_subst_comptype: `%%%%`(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, var_3) + -- (fun_subst_typeuse: `%%%%`(tu'#5, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}, var_2))*{var_2 <- `var_2*`, tu'#5 <- `tu'*`} + -- 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'*`} + -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) + +;; ../../../../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*, `tv'*` : typevar*, `tu'*` : typeuse*, var_1 : (typevar*, typeuse*)?, `var_0*` : subtype*}: + `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) + -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} -- (wf_typevar: `%`(tv'#4))*{tv'#4 <- `tv'*`} -- (wf_typeuse: `%`(tu'#6))*{tu'#6 <- `tu'*`} - -- if ((tv'#5*{tv'#5 <- `tv'*`}, tu'#7*{tu'#7 <- `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) + -- if ((tv'#5*{tv'#5 <- `tv'*`}, tu'#7*{tu'#7 <- `tu'*`}) = !(var_1)) + +;; ../../../../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#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `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 @@ -1901,385 +2448,646 @@ def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype def $subst_addrtype{at : addrtype, `tv*` : typevar*, `tu*` : typeuse*}(at, tv#68*{tv#68 <- `tv*`}, tu#68*{tu#68 <- `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#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `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#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `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#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 fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : valtype, var_0 : valtype}: + `%%%%`(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_valtype: `%%%%`(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}, var_1) + -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_memtype(memtype : memtype, typevar*, typeuse*) : memtype +relation fun_subst_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) + rule fun_subst_memtype_case_0{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)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_tabletype(tabletype : tabletype, typevar*, typeuse*) : tabletype +relation fun_subst_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*`}))) + rule fun_subst_tabletype_case_0{at : addrtype, lim : limits, rt : reftype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : reftype, var_0 : reftype}: + `%%%%`(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- fun_subst_reftype: `%%%%`(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}, var_1) + -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_externtype(externtype : externtype, typevar*, typeuse*) : externtype +relation fun_subst_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*`}))) + rule fun_subst_externtype_case_0{jt : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_1 : tagtype, var_0 : tagtype}: + `%%%%`(TAG_externtype(jt), tv#75*{tv#75 <- `tv*`}, tu#75*{tu#75 <- `tu*`}, TAG_externtype(var_0)) + -- fun_subst_tagtype: `%%%%`(jt, tv#76*{tv#76 <- `tv*`}, tu#76*{tu#76 <- `tu*`}, var_1) + -- fun_subst_tagtype: `%%%%`(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(TAG_externtype(var_1)) + ;; ../../../../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*`}))) + rule fun_subst_externtype_case_1{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : globaltype, var_0 : globaltype}: + `%%%%`(GLOBAL_externtype(gt), tv#77*{tv#77 <- `tv*`}, tu#77*{tu#77 <- `tu*`}, GLOBAL_externtype(var_0)) + -- fun_subst_globaltype: `%%%%`(gt, tv#78*{tv#78 <- `tv*`}, tu#78*{tu#78 <- `tu*`}, var_1) + -- fun_subst_globaltype: `%%%%`(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(GLOBAL_externtype(var_1)) + ;; ../../../../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*`}))) + rule fun_subst_externtype_case_2{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : tabletype, var_0 : tabletype}: + `%%%%`(TABLE_externtype(tt), tv#79*{tv#79 <- `tv*`}, tu#79*{tu#79 <- `tu*`}, TABLE_externtype(var_0)) + -- fun_subst_tabletype: `%%%%`(tt, tv#80*{tv#80 <- `tv*`}, tu#80*{tu#80 <- `tu*`}, var_1) + -- fun_subst_tabletype: `%%%%`(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(TABLE_externtype(var_1)) + ;; ../../../../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*`}))) + rule fun_subst_externtype_case_3{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : memtype, var_0 : memtype}: + `%%%%`(MEM_externtype(mt), tv#81*{tv#81 <- `tv*`}, tu#81*{tu#81 <- `tu*`}, MEM_externtype(var_0)) + -- fun_subst_memtype: `%%%%`(mt, tv#82*{tv#82 <- `tv*`}, tu#82*{tu#82 <- `tu*`}, var_1) + -- fun_subst_memtype: `%%%%`(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(MEM_externtype(var_1)) + ;; ../../../../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 fun_subst_externtype_case_4{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_1 : typeuse, var_0 : typeuse}: + `%%%%`(FUNC_externtype(tu'), tv#83*{tv#83 <- `tv*`}, tu#83*{tu#83 <- `tu*`}, FUNC_externtype(var_0)) + -- fun_subst_typeuse: `%%%%`(tu', tv#84*{tv#84 <- `tv*`}, tu#84*{tu#84 <- `tu*`}, var_1) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(FUNC_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype +relation fun_subst_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*`})) + rule fun_subst_moduletype_case_0{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_3*` : externtype*, `var_2*` : externtype*, `var_1*` : externtype*, `var_0*` : externtype*}: + `%%%%`(`%->%`_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(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- (fun_subst_externtype: `%%%%`(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`}, var_3))*{var_3 <- `var_3*`, xt_2#2 <- `xt_2*`} + -- (fun_subst_externtype: `%%%%`(xt_1#2, tv#86*{tv#86 <- `tv*`}, tu#86*{tu#86 <- `tu*`}, var_2))*{var_2 <- `var_2*`, xt_1#2 <- `xt_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*`} + -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_all_valtype(valtype : valtype, typeuse*) : valtype +relation fun_subst_all_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%`_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#9*{subtype#9 <- `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: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#503*{valtype#503 <- `valtype*`}), var_0) + -- (fun_free_valtype: `%%`(valtype, var_1))*{var_1 <- `var_1*`, valtype <- `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{var_0 : free}: + `%%`(I8_storagetype, var_0) + -- fun_free_packtype: `%%`(I8_packtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_8{var_0 : free}: + `%%`(I16_storagetype, var_0) + -- fun_free_packtype: `%%`(I16_packtype, var_0) + +;; ../../../../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#5?{mut#5 <- `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*`} + -- 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#3?{final#3 <- `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#9*{subtype#9 <- `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 -def $free_tagtype(tagtype : tagtype) : free +relation fun_free_tagtype: `%%`(tagtype, 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_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 -def $free_globaltype(globaltype : globaltype) : free +relation fun_free_globaltype: `%%`(globaltype, 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 fun_free_globaltype_case_0{`mut?` : mut?, valtype : valtype, var_0 : free}: + `%%`(`%%`_globaltype(mut#6?{mut#6 <- `mut?`}, valtype), var_0) + -- fun_free_valtype: `%%`(valtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_memtype(memtype : memtype) : free +relation fun_free_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) + rule fun_free_memtype_case_0{addrtype : addrtype, limits : limits, var_0 : free}: + `%%`(`%%PAGE`_memtype(addrtype, limits), var_0) + -- fun_free_addrtype: `%%`(addrtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tabletype(tabletype : tabletype) : free +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_1 : free, var_0 : free}: + `%%`(`%%%`_tabletype(addrtype, limits, reftype), var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype, var_1) + -- fun_free_addrtype: `%%`(addrtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_datatype(datatype : datatype) : free +relation fun_free_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 []} + rule fun_free_datatype_case_0: + `%%`(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 fun_free_elemtype: `%%`(elemtype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_elemtype{reftype : reftype}(reftype) = $free_reftype(reftype) + 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 -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 - def $free_externtype{globaltype : globaltype}(GLOBAL_externtype(globaltype)) = $free_globaltype(globaltype) + 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{memtype : memtype}(MEM_externtype(memtype)) = $free_memtype(memtype) + rule fun_free_externtype_case_2{memtype : memtype, var_0 : free}: + `%%`(MEM_externtype(memtype), var_0) + -- fun_free_memtype: `%%`(memtype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tabletype : tabletype}(TABLE_externtype(tabletype)) = $free_tabletype(tabletype) + 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{typeuse : typeuse}(FUNC_externtype(typeuse)) = $free_typeuse(typeuse) + 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 -def $free_moduletype(moduletype : moduletype) : free +relation fun_free_moduletype: `%%`(moduletype, 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 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.3-syntax.instructions.spectec syntax num_ = @@ -2794,9 +3602,10 @@ relation wf_shape: `%`(shape) -- if (($lsize(lanetype) * $proj_dim_0(dim).0) = 128) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $dim(shape : shape) : dim +relation fun_dim: `%%`(shape, dim) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) + rule fun_dim_case_0{Lnn : lanetype, N : nat}: + `%%`(`%X%`_shape(Lnn, `%`_dim(N)), `%`_dim(N)) -- wf_dim: `%`(`%`_dim(N)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4460,11 +5269,12 @@ relation wf_instr: `%`(instr) -- 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*}: + rule instr_case_95{bshape : bshape, `laneidx*` : laneidx*, var_0 : dim}: `%`(VSHUFFLE_instr(bshape, `laneidx*`)) -- wf_bshape: `%`(bshape) -- (wf_uN: `%%`(8, laneidx))*{laneidx <- `laneidx*`} - -- if (`%`_dim(|laneidx*{laneidx <- `laneidx*`}|) = $dim($proj_bshape_0(bshape).0)) + -- if (`%`_dim(|laneidx*{laneidx <- `laneidx*`}|) = var_0) + -- fun_dim: `%%`($proj_bshape_0(bshape).0, var_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__}: @@ -4511,7 +5321,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 @@ -4581,305 +5390,687 @@ relation wf_instr: `%`(instr) syntax expr = instr* ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $memarg0 : memarg +relation fun_memarg0: `%`(memarg) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} + rule fun_memarg0_case_0: + `%`({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 +relation fun_const: `%%%`(consttype, 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) + rule fun_const_case_0{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) + rule fun_const_case_1{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) + rule fun_const_case_2{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) + rule fun_const_case_3{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) + rule fun_const_case_4{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 -def $free_shape(shape : shape) : free +relation fun_free_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) + rule fun_free_shape_case_0{lanetype : lanetype, dim : dim, var_0 : free}: + `%%`(`%X%`_shape(lanetype, dim), var_0) + -- fun_free_lanetype: `%%`(lanetype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_blocktype(blocktype : blocktype) : free +relation fun_free_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?`}) + rule fun_free_blocktype_case_0{`valtype?` : valtype?, `var_1?` : free?, var_0 : free}: + `%%`(_RESULT_blocktype(valtype#505?{valtype#505 <- `valtype?`}), var_0) + -- (fun_free_valtype: `%%`(valtype, var_1))?{var_1 <- `var_1?`, valtype <- `valtype?`} + -- fun_free_opt: `%%`(var_1?{var_1 <- `var_1?`}, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) + rule fun_free_blocktype_case_1{typeidx : uN, var_0 : free}: + `%%`(_IDX_blocktype(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_catch(catch : catch) : free +relation fun_free_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) + rule fun_free_catch_case_0{tagidx : uN, labelidx : uN, var_1 : free, var_0 : free}: + `%%`(CATCH_catch(tagidx, labelidx), var_0 +++ var_1) + -- fun_free_labelidx: `%%`(labelidx, var_1) + -- fun_free_tagidx: `%%`(tagidx, var_0) + ;; ../../../../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) + rule fun_free_catch_case_1{tagidx : uN, labelidx : uN, var_1 : free, var_0 : free}: + `%%`(CATCH_REF_catch(tagidx, labelidx), var_0 +++ var_1) + -- fun_free_labelidx: `%%`(labelidx, var_1) + -- fun_free_tagidx: `%%`(tagidx, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{labelidx : uN}(CATCH_ALL_catch(labelidx)) = $free_labelidx(labelidx) + rule fun_free_catch_case_2{labelidx : uN, var_0 : free}: + `%%`(CATCH_ALL_catch(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) + rule fun_free_catch_case_3{labelidx : uN, var_0 : free}: + `%%`(CATCH_ALL_REF_catch(labelidx), var_0) + -- fun_free_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'*`}) +;; ../../../../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) -- 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 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 []} +;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_3{`valtype*?` : valtype*?, `var_2*?` : free*?, `var_1?` : free?, var_0 : free}: + `%%`(SELECT_instr(valtype#506*{valtype#506 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`}), var_0) + -- (fun_free_valtype: `%%`(valtype, var_2))*{var_2 <- `var_2*`, valtype <- `valtype*`}?{`var_2*` <- `var_2*?`, `valtype*` <- `valtype*?`} + -- (fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1))?{`var_2*` <- `var_2*?`, var_1 <- `var_1?`} + -- fun_free_opt: `%%`(var_1?{var_1 <- `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, var_0 : free}: + `%%`(BR_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_8{labelidx : uN, var_0 : free}: + `%%`(BR_IF_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_9{`labelidx*` : labelidx*, labelidx' : uN, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(BR_TABLE_instr(labelidx#1*{labelidx#1 <- `labelidx*`}, labelidx'), var_0 +++ var_2) + -- fun_free_labelidx: `%%`(labelidx', var_2) + -- (fun_free_labelidx: `%%`(labelidx, var_1))*{var_1 <- `var_1*`, labelidx <- `labelidx*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_10{labelidx : uN, var_0 : free}: + `%%`(BR_ON_NULL_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_11{labelidx : uN, var_0 : free}: + `%%`(BR_ON_NON_NULL_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../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_2 : free, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2), var_0 +++ var_1 +++ var_2) + -- fun_free_reftype: `%%`(reftype_2, var_2) + -- fun_free_reftype: `%%`(reftype_1, var_1) + -- fun_free_labelidx: `%%`(labelidx, 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_2 : free, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2), var_0 +++ var_1 +++ var_2) + -- fun_free_reftype: `%%`(reftype_2, var_2) + -- fun_free_reftype: `%%`(reftype_1, var_1) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_14{funcidx : uN, var_0 : free}: + `%%`(CALL_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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_1 : free, var_0 : free}: + `%%`(CALL_INDIRECT_instr(tableidx, typeuse), var_0 +++ var_1) + -- fun_free_typeuse: `%%`(typeuse, var_1) + -- fun_free_tableidx: `%%`(tableidx, 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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_18{funcidx : uN, var_0 : free}: + `%%`(RETURN_CALL_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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_1 : free, var_0 : free}: + `%%`(RETURN_CALL_INDIRECT_instr(tableidx, typeuse), var_0 +++ var_1) + -- fun_free_typeuse: `%%`(typeuse, var_1) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_21{tagidx : uN, var_0 : free}: + `%%`(THROW_instr(tagidx), var_0) + -- fun_free_tagidx: `%%`(tagidx, var_0) + + ;; ../../../../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 []}) -- 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#43187?{sx#43187 <- `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 []} + + ;; ../../../../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_4*` : free*, 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_3) + -- (fun_free_instr: `%%`(instr, var_4))*{var_4 <- `var_4*`, instr <- `instr*`} + -- fun_free_list: `%%`(var_4*{var_4 <- `var_4*`}, var_3) + -- (fun_free_catch: `%%`(catch, var_2))*{var_2 <- `var_2*`, catch <- `catch*`} + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, 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_, var_0 : free}: + `%%`(CONST_instr(numtype, numlit), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_25{numtype : numtype, unop : unop_, var_0 : free}: + `%%`(UNOP_instr(numtype, unop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_26{numtype : numtype, binop : binop_, var_0 : free}: + `%%`(BINOP_instr(numtype, binop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_27{numtype : numtype, testop : testop_, var_0 : free}: + `%%`(TESTOP_instr(numtype, testop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_28{numtype : numtype, relop : relop_, var_0 : free}: + `%%`(RELOP_instr(numtype, relop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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__, var_1 : free, var_0 : free}: + `%%`(CVTOP_instr(numtype_1, numtype_2, cvtop), var_0 +++ var_1) + -- fun_free_numtype: `%%`(numtype_2, var_1) + -- fun_free_numtype: `%%`(numtype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_30{vectype : vectype, veclit : uN, var_0 : free}: + `%%`(VCONST_instr(vectype, veclit), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_31{vectype : vectype, vvunop : vvunop, var_0 : free}: + `%%`(VVUNOP_instr(vectype, vvunop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_32{vectype : vectype, vvbinop : vvbinop, var_0 : free}: + `%%`(VVBINOP_instr(vectype, vvbinop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_33{vectype : vectype, vvternop : vvternop, var_0 : free}: + `%%`(VVTERNOP_instr(vectype, vvternop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_34{vectype : vectype, vvtestop : vvtestop, var_0 : free}: + `%%`(VVTESTOP_instr(vectype, vvtestop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_35{shape : shape, vunop : vunop_, var_0 : free}: + `%%`(VUNOP_instr(shape, vunop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_36{shape : shape, vbinop : vbinop_, var_0 : free}: + `%%`(VBINOP_instr(shape, vbinop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_37{shape : shape, vternop : vternop_, var_0 : free}: + `%%`(VTERNOP_instr(shape, vternop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_38{shape : shape, vtestop : vtestop_, var_0 : free}: + `%%`(VTESTOP_instr(shape, vtestop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_39{shape : shape, vrelop : vrelop_, var_0 : free}: + `%%`(VRELOP_instr(shape, vrelop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_40{ishape : ishape, vshiftop : vshiftop_, var_0 : free}: + `%%`(VSHIFTOP_instr(ishape, vshiftop), var_0) + -- fun_free_shape: `%%`($proj_ishape_0(ishape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_41{ishape : ishape, var_0 : free}: + `%%`(VBITMASK_instr(ishape), var_0) + -- fun_free_shape: `%%`($proj_ishape_0(ishape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_42{bshape : bshape, vswizzlop : vswizzlop_, var_0 : free}: + `%%`(VSWIZZLOP_instr(bshape, vswizzlop), var_0) + -- fun_free_shape: `%%`($proj_bshape_0(bshape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_43{bshape : bshape, `laneidx*` : laneidx*, var_0 : free}: + `%%`(VSHUFFLE_instr(bshape, laneidx#1*{laneidx#1 <- `laneidx*`}), var_0) + -- fun_free_shape: `%%`($proj_bshape_0(bshape).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTUNOP_instr(ishape_1, ishape_2, vextunop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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, var_1 : free, var_0 : free}: + `%%`(VNARROW_instr(ishape_1, ishape_2, sx), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VCVTOP_instr(shape_1, shape_2, vcvtop), var_0 +++ var_1) + -- fun_free_shape: `%%`(shape_2, var_1) + -- fun_free_shape: `%%`(shape_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_49{shape : shape, var_0 : free}: + `%%`(VSPLAT_instr(shape), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VEXTRACT_LANE_instr(shape, sx#43187?{sx#43187 <- `sx?`}, laneidx), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_51{shape : shape, laneidx : uN, var_0 : free}: + `%%`(VREPLACE_LANE_instr(shape, laneidx), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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, var_0 : free}: + `%%`(`REF.FUNC`_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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#43188?{sx#43188 <- `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#43189?{sx#43189 <- `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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_61{typeidx : uN, var_0 : free}: + `%%`(`STRUCT.NEW`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_62{typeidx : uN, var_0 : free}: + `%%`(`STRUCT.NEW_DEFAULT`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(`STRUCT.GET`_instr(sx#43188?{sx#43188 <- `sx?`}, typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_64{typeidx : uN, u32 : uN, var_0 : free}: + `%%`(`STRUCT.SET`_instr(typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_65{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.NEW`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_66{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.NEW_DEFAULT`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_67{typeidx : uN, u32 : uN, var_0 : free}: + `%%`(`ARRAY.NEW_FIXED`_instr(typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_68{typeidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.NEW_DATA`_instr(typeidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_69{typeidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_70{`sx?` : sx?, typeidx : uN, var_0 : free}: + `%%`(`ARRAY.GET`_instr(sx#43189?{sx#43189 <- `sx?`}, typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_71{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.SET`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_73{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.FILL`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`ARRAY.COPY`_instr(typeidx_1, typeidx_2), var_0 +++ var_1) + -- fun_free_typeidx: `%%`(typeidx_2, var_1) + -- fun_free_typeidx: `%%`(typeidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_75{typeidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.INIT_DATA`_instr(typeidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_76{typeidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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*, free : free}(instr#4*{instr#4 <- `instr*`}) = free[LABELS_free = $shift_labelidxs(free.LABELS_free)] + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_79{localidx : uN, var_0 : free}: + `%%`(`LOCAL.GET`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_80{localidx : uN, var_0 : free}: + `%%`(`LOCAL.SET`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_81{localidx : uN, var_0 : free}: + `%%`(`LOCAL.TEE`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_82{globalidx : uN, var_0 : free}: + `%%`(`GLOBAL.GET`_instr(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_83{globalidx : uN, var_0 : free}: + `%%`(`GLOBAL.SET`_instr(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_84{tableidx : uN, var_0 : free}: + `%%`(`TABLE.GET`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_85{tableidx : uN, var_0 : free}: + `%%`(`TABLE.SET`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_86{tableidx : uN, var_0 : free}: + `%%`(`TABLE.SIZE`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_87{tableidx : uN, var_0 : free}: + `%%`(`TABLE.GROW`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_88{tableidx : uN, var_0 : free}: + `%%`(`TABLE.FILL`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`TABLE.COPY`_instr(tableidx_1, tableidx_2), var_0 +++ var_1) + -- fun_free_tableidx: `%%`(tableidx_2, var_1) + -- fun_free_tableidx: `%%`(tableidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_90{tableidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`TABLE.INIT`_instr(tableidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_91{elemidx : uN, var_0 : free}: + `%%`(`ELEM.DROP`_instr(elemidx), var_0) + -- fun_free_elemidx: `%%`(elemidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(LOAD_instr(numtype, loadop#1?{loadop#1 <- `loadop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(STORE_instr(numtype, storeop#1?{storeop#1 <- `storeop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VLOAD_instr(vectype, vloadop#1?{vloadop#1 <- `vloadop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VSTORE_instr(vectype, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_98{memidx : uN, var_0 : free}: + `%%`(`MEMORY.SIZE`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_99{memidx : uN, var_0 : free}: + `%%`(`MEMORY.GROW`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_100{memidx : uN, var_0 : free}: + `%%`(`MEMORY.FILL`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`MEMORY.COPY`_instr(memidx_1, memidx_2), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx_2, var_1) + -- fun_free_memidx: `%%`(memidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_102{memidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`MEMORY.INIT`_instr(memidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_103{dataidx : uN, var_0 : free}: + `%%`(`DATA.DROP`_instr(dataidx), var_0) + -- fun_free_dataidx: `%%`(dataidx, var_0) + +;; ../../../../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*, free : free, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: + `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- (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) -- wf_free: `%`(free) - -- if (free = $free_list($free_instr(instr#5)*{instr#5 <- `instr*`})) + -- if (free = 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.4-syntax.modules.spectec syntax elemmode = @@ -5067,98 +6258,170 @@ 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 fun_free_tag: `%%`(tag, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) + 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_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 -def $free_mem(mem : mem) : free +relation fun_free_mem: `%%`(mem, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) + rule fun_free_mem_case_0{memtype : memtype, var_0 : free}: + `%%`(MEMORY_mem(memtype), var_0) + -- fun_free_memtype: `%%`(memtype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_table(table : table) : free +relation fun_free_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) + 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_local(local : local) : free +relation fun_free_local: `%%`(local, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) + 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_func(func : func) : free +relation fun_free_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 = []] + rule fun_free_func_case_0{typeidx : uN, `local*` : local*, expr : instr*, var_3 : free, `var_2*` : free*, var_1 : free, var_0 : free}: + `%%`(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr), var_0 +++ var_1 +++ var_3[LOCALS_free = []]) + -- fun_free_block: `%%`(expr, var_3) + -- (fun_free_local: `%%`(local, var_2))*{var_2 <- `var_2*`, local <- `local*`} + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_datamode(datamode : datamode) : free +relation fun_free_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) + rule fun_free_datamode_case_0{memidx : uN, expr : instr*, var_1 : free, var_0 : free}: + `%%`(ACTIVE_datamode(memidx, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_memidx: `%%`(memidx, var_0) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode(PASSIVE_datamode) = {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 []}) -- 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 +relation fun_free_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) + 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_elemmode(elemmode : elemmode) : free +relation fun_free_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) + rule fun_free_elemmode_case_0{tableidx : uN, expr : instr*, var_1 : free, var_0 : free}: + `%%`(ACTIVE_elemmode(tableidx, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_tableidx: `%%`(tableidx, var_0) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} + rule fun_free_elemmode_case_1: + `%%`(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 []} + rule fun_free_elemmode_case_2: + `%%`(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 +relation fun_free_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) + 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_start(start : start) : free +relation fun_free_start: `%%`(start, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) + rule fun_free_start_case_0{funcidx : uN, var_0 : free}: + `%%`(START_start(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_import(import : import) : free +relation fun_free_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) + 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 -def $free_export(export : export) : free +relation fun_free_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) + rule fun_free_export_case_0{name : name, externidx : externidx, var_0 : free}: + `%%`(EXPORT_export(name, externidx), var_0) + -- fun_free_externidx: `%%`(externidx, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_module(module : module) : free +relation fun_free_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*`}) + 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_21*` : free*, var_20 : free, `var_19*` : free*, var_18 : free, `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_8 +++ var_10 +++ var_12 +++ var_14 +++ var_16 +++ var_18 +++ var_20) + -- (fun_free_export: `%%`(export, var_21))*{var_21 <- `var_21*`, export <- `export*`} + -- fun_free_list: `%%`(var_21*{var_21 <- `var_21*`}, var_20) + -- (fun_free_import: `%%`(import, var_19))*{var_19 <- `var_19*`, import <- `import*`} + -- fun_free_list: `%%`(var_19*{var_19 <- `var_19*`}, var_18) + -- (fun_free_start: `%%`(start, var_17))?{var_17 <- `var_17?`, start <- `start?`} + -- fun_free_opt: `%%`(var_17?{var_17 <- `var_17?`}, var_16) + -- (fun_free_elem: `%%`(elem, var_15))*{var_15 <- `var_15*`, elem <- `elem*`} + -- fun_free_list: `%%`(var_15*{var_15 <- `var_15*`}, var_14) + -- (fun_free_data: `%%`(data, var_13))*{var_13 <- `var_13*`, data <- `data*`} + -- fun_free_list: `%%`(var_13*{var_13 <- `var_13*`}, var_12) + -- (fun_free_func: `%%`(func, var_11))*{var_11 <- `var_11*`, func <- `func*`} + -- fun_free_list: `%%`(var_11*{var_11 <- `var_11*`}, var_10) + -- (fun_free_table: `%%`(table, var_9))*{var_9 <- `var_9*`, table <- `table*`} + -- fun_free_list: `%%`(var_9*{var_9 <- `var_9*`}, var_8) + -- (fun_free_mem: `%%`(mem, var_7))*{var_7 <- `var_7*`, mem <- `mem*`} + -- fun_free_list: `%%`(var_7*{var_7 <- `var_7*`}, 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 -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 = @@ -5219,60 +6482,97 @@ 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'*` : deftype*}(dt#2*{dt#2 <- `dt*`} ++ [dt_n]) = dt'*{dt' <- `dt'*`} ++ [$subst_all_deftype(dt_n, $typeuse_deftype(dt')*{dt' <- `dt'*`})] - -- if (dt'#1*{dt'#1 <- `dt'*`} = $clos_deftypes(dt#3*{dt#3 <- `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, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: + `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- fun_clos_deftypes: `%%`(dt#3*{dt#3 <- `dt*`}, var_1) + -- fun_subst_all_deftype: `%%%`(dt_n, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + -- if (dt'#1*{dt'#1 <- `dt'*`} = var_1) } ;; ../../../../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 - def $clos_valtype{C : context, t : valtype, `dt*` : deftype*}(C, t) = $subst_all_valtype(t, $typeuse_deftype(dt)*{dt <- `dt*`}) - -- if (dt#4*{dt#4 <- `dt*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_valtype_case_0{C : context, t : valtype, `dt*` : deftype*, var_1 : deftype*, var_0 : valtype}: + `%%%`(C, t, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_valtype: `%%%`(t, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#4*{dt#4 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_deftype(context : context, deftype : deftype) : deftype +relation fun_clos_deftype: `%%%`(context, deftype, deftype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_deftype{C : context, dt : deftype, `dt'*` : deftype*}(C, dt) = $subst_all_deftype(dt, $typeuse_deftype(dt')*{dt' <- `dt'*`}) - -- if (dt'#2*{dt'#2 <- `dt'*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_deftype_case_0{C : context, dt : deftype, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: + `%%%`(C, dt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_deftype: `%%%`(dt, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + -- if (dt'#2*{dt'#2 <- `dt'*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_tagtype(context : context, tagtype : tagtype) : tagtype +relation fun_clos_tagtype: `%%%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_tagtype{C : context, jt : typeuse, `dt*` : deftype*}(C, jt) = $subst_all_tagtype(jt, $typeuse_deftype(dt)*{dt <- `dt*`}) - -- if (dt#5*{dt#5 <- `dt*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_tagtype_case_0{C : context, jt : typeuse, `dt*` : deftype*, var_1 : deftype*, var_0 : tagtype}: + `%%%`(C, jt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_tagtype: `%%%`(jt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#5*{dt#5 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_externtype(context : context, externtype : externtype) : externtype +relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_externtype{C : context, xt : externtype, `dt*` : deftype*}(C, xt) = $subst_all_externtype(xt, $typeuse_deftype(dt)*{dt <- `dt*`}) - -- if (dt#6*{dt#6 <- `dt*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_externtype_case_0{C : context, xt : externtype, `dt*` : deftype*, var_1 : deftype*, var_0 : externtype}: + `%%%`(C, xt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_externtype: `%%%`(xt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#6*{dt#6 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_moduletype(context : context, moduletype : moduletype) : moduletype +relation fun_clos_moduletype: `%%%`(context, moduletype, moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_moduletype{C : context, mmt : moduletype, `dt*` : deftype*}(C, mmt) = $subst_all_moduletype(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}) - -- if (dt#7*{dt#7 <- `dt*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_moduletype_case_0{C : context, mmt : moduletype, `dt*` : deftype*, var_1 : deftype*, var_0 : moduletype}: + `%%%`(C, mmt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_moduletype: `%%%`(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#7*{dt#7 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -5316,10 +6616,11 @@ 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) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, 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)) + -- fun_unrolldt: `%%`(deftype, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Vectype_sub: `%|-%<:%`(context, vectype, vectype) @@ -5336,13 +6637,20 @@ 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_{rectype : rectype, n : n, C : context}(C, _DEF_heaptype(rectype, n)) = $unrolldt(_DEF_deftype(rectype, n)) + 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) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] + 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 rec { @@ -5410,7 +6718,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) `%|-%:OK`(C, _IDX_typeuse(typeidx)) -- wf_context: `%`(C) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:110.1-112.23 @@ -5419,7 +6726,6 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) -- wf_context: `%`(C) -- wf_subtype: `%`(st) -- wf_typeuse: `%`(REC_typeuse(i)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = st) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:114.1-116.35 @@ -5488,19 +6794,18 @@ 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)) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) - -- if (|`comptype'*`| = |`typeuse'**`|) -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} -- (if $before(typeuse, i))*{typeuse <- `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'*`} + -- (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) @@ -5537,7 +6842,6 @@ relation Comptype_sub: `%|-%<:%`(context, comptype, comptype) -- 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*`}))) - -- if (|`ft_1*`| = |`ft_2*`|) -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, ft_2 <- `ft_2*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:185.1-187.38 @@ -5560,19 +6864,21 @@ 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) -- wf_context: `%`(C) - -- if ($clos_deftype(C, deftype_1) = $clos_deftype(C, deftype_2)) + -- if (var_0 = var_1) + -- 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) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- 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)) + -- 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) @@ -5657,7 +6963,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0]), heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 @@ -5666,7 +6971,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_context: `%`(C) -- wf_heaptype: `%`(heaptype) -- wf_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])) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 @@ -5676,7 +6980,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(STRUCT_heaptype) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`})))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:69.1-71.49 @@ -5686,7 +6989,6 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_heaptype: `%`(ARRAY_heaptype) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:73.1-75.51 @@ -5696,17 +6998,14 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- 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*`})))) - -- 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*`})))) ;; ../../../../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*`}|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- if (i < |C.RECS_context|) -- if (C.RECS_context[i] = SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:81.1-84.25 @@ -5815,7 +7114,6 @@ relation Resulttype_sub: `%|-%<:%`(context, resulttype, resulttype) -- wf_context: `%`(C) -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} -- (wf_valtype: `%`(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*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:150.1-150.119 @@ -5873,8 +7171,6 @@ relation Instrtype_ok: `%|-%:OK`(context, instrtype) -- wf_instrtype: `%`(`%->_%%`_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*`} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5892,7 +7188,6 @@ relation Expand_use: `%~~_%%`(typeuse, context, comptype) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) - -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5909,20 +7204,18 @@ 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)) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) - -- if (|`comptype'*`| = |`yy**`|) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} -- if (|x*{x <- `x*`}| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} - -- if (|`comptype'*`| = |`x*`|) - -- (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'*`} + -- (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 { @@ -6048,8 +7341,6 @@ 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*`} ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec @@ -6180,41 +7471,35 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../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*}: + rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*, var_0 : deftype?}: `%|-%:OK`(C, CATCH_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`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|) + -- Expand: `%~~%`(!(var_0), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: + rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*, var_0 : deftype?}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`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|) + -- Expand: `%~~%`(!(var_0), `FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: `%|-%:OK`(C, CATCH_ALL_catch(l)) -- wf_context: `%`(C) -- wf_catch: `%`(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]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -6222,42 +7507,97 @@ relation Catch_ok: `%|-%:OK`(context, catch) `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) -- wf_context: `%`(C) -- wf_catch: `%`(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]) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -def $default_(valtype : valtype) : val?? +relation fun_default__before_fun_default__case_7: `%`(valtype) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_6{ht : heaptype}: + `%`(REF_valtype(?(), ht)) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_5{ht : heaptype}: + `%`(REF_valtype(?(NULL_null), ht)) + -- wf_val: `%`(`REF.NULL_ADDR`_val) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_4: + `%`(V128_valtype) + -- wf_val: `%`(VCONST_val(V128_vectype, `%`_vec_(0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_3{var_0 : fN}: + `%`(F64_valtype) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_2{var_0 : fN}: + `%`(F32_valtype) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_1: + `%`(I64_valtype) + -- 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 + rule fun_default__case_0: + `%`(I32_valtype) + -- 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 +relation fun_default_: `%%`(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))))) + rule fun_default__case_0: + `%%`(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))))) + rule fun_default__case_1: + `%%`(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)))))) + rule fun_default__case_2{var_0 : fN}: + `%%`(F32_valtype, ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + ;; ../../../../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)))))) + rule fun_default__case_3{var_0 : fN}: + `%%`(F64_valtype, ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, `%`_vec_(0)))) + rule fun_default__case_4: + `%%`(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)) + rule fun_default__case_5{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 + rule fun_default__case_6{ht : heaptype}: + `%%`(REF_valtype(?(), ht), ?(?())) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_7{x0 : valtype}: + `%%`(x0, ?()) + -- ~ fun_default__before_fun_default__case_7: `%`(x0) ;; ../../../../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}: + rule _{t : valtype, var_0 : val??}: `|-%DEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) - -- if (!($default_(t)) =/= ?()) + -- if (!(var_0) =/= ?()) + -- fun_default_: `%%`(t, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -6269,9 +7609,11 @@ relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) -- if (m < (2 ^ $size($numtype_addrtype(at)))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -def $is_packtype(storagetype : storagetype) : bool +relation fun_is_packtype: `%%`(storagetype, bool) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - def $is_packtype{zt : storagetype}(zt) = (zt =/= $storagetype_valtype($unpack(zt))) + rule fun_is_packtype_case_0{zt : storagetype, var_0 : valtype}: + `%%`(zt, (zt =/= $storagetype_valtype(var_0))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rec { @@ -6363,7 +7705,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) @@ -6373,7 +7714,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instrtype: `%`(`%->_%%`_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*`}) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:81.1-85.49 @@ -6382,9 +7722,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- (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*`}))) @@ -6394,7 +7732,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)]))) - -- 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) @@ -6404,36 +7741,35 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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)])) ;; ../../../../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))]))) + rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype, var_0 : 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(var_0)]))) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) -- wf_instr: `%`(BR_ON_CAST_instr(l, rt_1, rt_2)) - -- wf_instrtype: `%`(`%->_%%`_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|) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(var_0)]))) -- 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) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt) + -- fun_diffrt: `%%%`(rt_1, rt_2, var_0) ;; ../../../../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}: + rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype, var_0 : 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)]))) -- 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*`} ++ [$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) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) - -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) + -- Reftype_sub: `%|-%<:%`(C, var_0, rt) + -- fun_diffrt: `%%%`(rt_1, rt_2, var_0) ;; ../../../../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*}: @@ -6442,7 +7778,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:119.1-121.45 @@ -6452,7 +7787,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:123.1-127.45 @@ -6464,10 +7798,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:129.1-132.42 @@ -6489,7 +7821,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) @@ -6504,7 +7835,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) @@ -6521,27 +7851,24 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*`}))) - -- 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*`})) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*}: + rule throw{C : context, x : idx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*, var_0 : deftype?}: `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_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*`}))) - -- 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([]))) + -- Expand: `%~~%`(!(var_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*`}))) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:171.1-173.42 rule throw_ref{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: @@ -6578,9 +7905,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(`REF.FUNC`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:211.1-212.34 @@ -6641,83 +7966,82 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))]))) + rule `struct.new`{C : context, x : idx, `zt*` : storagetype*, `mut?*` : mut?*, `var_0*` : valtype*}: + `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- 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*`}))) + -- (fun_unpack: `%%`(zt, var_0))*{var_0 <- `var_0*`, 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*}: + rule `struct.new_default`{C : context, x : idx, `mut?*` : mut?*, `zt*` : storagetype*, `var_0*` : valtype*}: `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- 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*`}))) - -- 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*`} + -- (Defaultable: `|-%DEFAULTABLE`(var_0))*{var_0 <- `var_0*`} + -- (fun_unpack: `%%`(zt, var_0))*{var_0 <- `var_0*`, 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)]))) + rule `struct.get`{C : context, `sx?` : sx?, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, `mut?` : mut?, var_1 : bool, var_0 : valtype}: + `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([var_0]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([var_0]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, 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)) + -- if ((sx?{sx <- `sx?`} =/= ?()) <=> var_1) + -- fun_is_packtype: `%%`(zt, var_1) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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([]))) + rule `struct.set`{C : context, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, var_0 : valtype}: + `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) var_0]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) var_0]), [], `%`_resulttype([]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), 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), zt)) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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))]))) + rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([var_0 I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([var_0 I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: + rule `array.new_default`{C : context, x : idx, `mut?` : mut?, zt : storagetype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- 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))) - -- 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)) + -- Defaultable: `|-%DEFAULTABLE`(var_0) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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))]))) + rule `array.new_fixed`{C : context, x : idx, n : n, zt : storagetype, `mut?` : mut?, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype(var_0^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(var_0^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: @@ -6726,44 +8050,42 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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?`}, $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?`}, $storagetype_reftype(rt)))) - -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], 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}: + rule `array.new_data`{C : context, x : idx, y : idx, `mut?` : mut?, zt : storagetype, numtype : numtype, vectype : vectype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- 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))) - -- 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 ((var_0 = $valtype_numtype(numtype)) \/ (var_0 = $valtype_vectype(vectype))) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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)]))) + rule `array.get`{C : context, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?, var_1 : bool, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([var_0]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([var_0]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) - -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) + -- if ((sx?{sx <- `sx?`} =/= ?()) <=> var_1) + -- fun_is_packtype: `%%`(zt, var_1) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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([]))) + rule `array.set`{C : context, x : idx, zt : storagetype, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:305.1-306.43 rule `array.len`{C : context}: @@ -6773,14 +8095,14 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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([]))) + rule `array.fill`{C : context, x : idx, zt : storagetype, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0 I32_valtype]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0 I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: @@ -6790,9 +8112,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) @@ -6803,23 +8123,20 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))) - -- 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) ;; ../../../../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}: + rule `array.init_data`{C : context, x : idx, y : idx, zt : storagetype, numtype : numtype, vectype : vectype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- 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))) - -- 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 ((var_0 = $valtype_numtype(numtype)) \/ (var_0 = $valtype_vectype(vectype))) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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?}: @@ -6844,7 +8161,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:347.1-349.29 @@ -6854,7 +8170,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) -- wf_localtype: `%`(`%%`_localtype(init, t)) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:351.1-353.29 @@ -6864,7 +8179,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) -- wf_localtype: `%`(`%%`_localtype(init, t)) - -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_localtype(init, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:358.1-360.30 @@ -6874,7 +8188,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(mut?{mut <- `mut?`}, t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:362.1-364.29 @@ -6884,7 +8197,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:369.1-371.32 @@ -6894,7 +8206,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:373.1-375.32 @@ -6904,7 +8215,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.SET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:377.1-379.32 @@ -6914,7 +8224,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:381.1-383.32 @@ -6924,7 +8233,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:385.1-387.32 @@ -6934,7 +8242,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:389.1-393.36 @@ -6945,9 +8252,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6959,9 +8264,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -6972,7 +8275,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_reftype: `%`(rt) -- wf_instr: `%`(`ELEM.DROP`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:416.1-418.32 @@ -6982,7 +8284,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:420.1-422.32 @@ -6992,7 +8293,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:424.1-426.32 @@ -7002,7 +8302,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:428.1-431.38 @@ -7013,9 +8312,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:433.1-436.24 @@ -7025,9 +8322,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:438.1-440.24 @@ -7036,7 +8331,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_context: `%`(C) -- wf_instr: `%`(`DATA.DROP`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:451.1-454.44 @@ -7046,7 +8340,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(LOAD_instr(nt, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7057,7 +8350,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -7068,7 +8360,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(STORE_instr(nt, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7079,7 +8370,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)) - -- 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) @@ -7090,7 +8380,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7101,7 +8390,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7112,7 +8400,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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) @@ -7123,7 +8410,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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) @@ -7134,7 +8420,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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))) @@ -7146,7 +8431,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VSTORE_instr(V128_vectype, x, memarg)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7157,7 +8441,6 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instr: `%`(VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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))) @@ -7296,12 +8579,13 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*}: + rule vshuffle{C : context, sh : bshape, `i*` : laneidx*, var_0 : dim}: `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_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*`} + -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0(var_0).0)))*{i <- `i*`} + -- fun_dim: `%%`($proj_bshape_0(sh).0, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:584.1-585.44 rule vsplat{C : context, sh : shape}: @@ -7311,20 +8595,22 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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}: + rule vextract_lane{C : context, sh : shape, `sx?` : sx?, i : laneidx, var_0 : dim}: `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) -- wf_context: `%`(C) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) - -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) + -- if ($proj_uN_0(i).0 < $proj_dim_0(var_0).0) + -- fun_dim: `%%`(sh, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:591.1-593.21 - rule vreplace_lane{C : context, sh : shape, i : laneidx}: + rule vreplace_lane{C : context, sh : shape, i : laneidx, var_0 : dim}: `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) + -- if ($proj_uN_0(i).0 < $proj_dim_0(var_0).0) + -- fun_dim: `%%`(sh, var_0) ;; ../../../../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__}: @@ -7370,23 +8656,20 @@ 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*`}))) -- 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*`}))) - -- if (|`init*`| = |`t*`|) -- (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*`}))) -- 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*`| = |`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*`}))) + -- 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}: @@ -7423,11 +8706,11 @@ relation Expr_ok: `%|-%:%`(context, expr, resulttype) ;; ../../../../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}: + rule _{t : valtype, var_0 : val??}: `|-%NONDEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) - -- if (!($default_(t)) = ?()) + -- if (!(var_0) = ?()) + -- fun_default_: `%%`(t, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7509,7 +8792,6 @@ relation Instr_const: `%|-%CONST`(context, instr) -- wf_context: `%`(C) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_globaltype: `%`(`%%`_globaltype(?(), t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -7520,9 +8802,7 @@ relation Instr_const: `%|-%CONST`(context, instr) -- 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)) - -- 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)]) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -7548,23 +8828,25 @@ 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*`}) -- 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)) -- 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)) + -- 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) -- wf_context: `%`(C) -- wf_tag: `%`(TAG_tag(tagtype)) -- Tagtype_ok: `%|-%:OK`(C, tagtype) + -- fun_clos_tagtype: `%%%`(C, tagtype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Global_ok: `%|-%:%`(context, global, globaltype) @@ -7622,13 +8904,11 @@ 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|) -- 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 []}) -- 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*`})) @@ -7646,7 +8926,6 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) -- wf_context: `%`(C) -- wf_datamode: `%`(ACTIVE_datamode(x, expr)) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) - -- 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)) @@ -7682,7 +8961,6 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) -- wf_reftype: `%`(rt) -- wf_elemmode: `%`(ACTIVE_elemmode(x, expr)) -- wf_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, expr, $valtype_addrtype(at)) @@ -7706,17 +8984,17 @@ relation Start_ok: `%|-%:OK`(context, start) -- wf_context: `%`(C) -- wf_start: `%`(START_start(x)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `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)) + rule _{C : context, name_1 : name, name_2 : name, xt : externtype, var_0 : externtype}: + `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), var_0) -- wf_context: `%`(C) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) -- Externtype_ok: `%|-%:OK`(C, xt) + -- fun_clos_externtype: `%%%`(C, xt, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Externidx_ok: `%|-%:%`(context, externidx, externtype) @@ -7726,7 +9004,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(TAG_externidx(x)) -- wf_externtype: `%`(TAG_externtype(jt)) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) -- if (C.TAGS_context[$proj_uN_0(x).0] = jt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7735,7 +9012,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(GLOBAL_externidx(x)) -- wf_externtype: `%`(GLOBAL_externtype(gt)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = gt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7744,7 +9020,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(MEM_externidx(x)) -- wf_externtype: `%`(MEM_externtype(mt)) - -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = mt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7753,7 +9028,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(TABLE_externidx(x)) -- wf_externtype: `%`(TABLE_externtype(tt)) - -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7762,7 +9036,6 @@ relation Externidx_ok: `%|-%:%`(context, externidx, externtype) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(dt))) - -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7833,16 +9106,18 @@ 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*`}))) + 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) -- 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) ;; ../../../../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_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) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} @@ -7854,34 +9129,27 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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*`})) -- 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 (x*{x <- `x*`} = var_1) -- 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*`})) + -- 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 = @@ -8004,62 +9272,127 @@ def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $signed_(N : N, nat : nat) : int +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?? +relation fun_sx_before_fun_sx_case_7: `%`(storagetype) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx(I32_storagetype) = ?(?()) + rule fun_sx_case_6: + `%`(I16_storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx(I64_storagetype) = ?(?()) + rule fun_sx_case_5: + `%`(I8_storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx(F32_storagetype) = ?(?()) + rule fun_sx_case_4: + `%`(V128_storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx(F64_storagetype) = ?(?()) + rule fun_sx_case_3: + `%`(F64_storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx(V128_storagetype) = ?(?()) + rule fun_sx_case_2: + `%`(F32_storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx(I8_storagetype) = ?(?(S_sx)) + rule fun_sx_case_1: + `%`(I64_storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx(I16_storagetype) = ?(?(S_sx)) - def $sx{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_sx_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_sx: `%%`(storagetype, sx??) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_0: + `%%`(I32_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_1: + `%%`(I64_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_2: + `%%`(F32_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_3: + `%%`(F64_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_4: + `%%`(V128_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_5: + `%%`(I8_storagetype, ?(?(S_sx))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_6: + `%%`(I16_storagetype, ?(?(S_sx))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_7{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_sx_before_fun_sx_case_7: `%`(x0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $zero(lanetype : lanetype) : lane_ +relation fun_zero: `%%`(lanetype, lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, `%`_uN(0)) + rule fun_zero_case_0: + `%%`(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)) + rule fun_zero_case_1: + `%%`(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)) + rule fun_zero_case_2: + `%%`(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)) + rule fun_zero_case_3: + `%%`(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)))))) + rule fun_zero_case_4{var_0 : fN}: + `%%`(F32_lanetype, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + ;; ../../../../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)))))) + rule fun_zero_case_5{var_0 : fN}: + `%%`(F64_lanetype, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -8093,7 +9426,8 @@ def $ineg_(N : N, iN : iN) : iN ;; ../../../../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 @@ -8105,13 +9439,18 @@ 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))) + rule fun_iextend__case_0{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)))))) + 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) + -- wf_uN: `%%`(N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN @@ -8132,34 +9471,58 @@ def $imul_(N : N, iN : iN, iN : iN) : iN -- 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))) + 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)))) -- 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)) = ?() + 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, ?()) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) + -- if (((var_0 : int <:> rat) / (var_1 : 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)))))) + 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) + -- wf_uN: `%%`(N, `%`_uN(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))) + 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)))) -- 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)) = ?() + 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)))))))) - -- wf_uN: `%%`(N, `%`_uN($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))) + 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))) + -- 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) + -- wf_uN: `%%`(N, `%`_uN(var_0)) + -- if ((j_1 = var_1) /\ (j_2 = var_2)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -8170,7 +9533,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 @@ -8181,7 +9546,9 @@ 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 @@ -8189,8 +9556,11 @@ def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN 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) + -- wf_uN: `%%`(N, `%`_uN(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 @@ -8198,8 +9568,11 @@ def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN 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) + -- wf_uN: `%%`(N, `%`_uN(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 @@ -8247,15 +9620,17 @@ def $ibitselect_(N : N, iN : iN, iN : iN, iN : iN) : iN 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 +relation fun_ieqz_: `%%%`(N, 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))) + rule fun_ieqz__case_0{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 +relation fun_inez_: `%%%`(N, 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))) + rule fun_inez__case_0{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 @@ -8276,8 +9651,10 @@ def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 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))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -8285,8 +9662,10 @@ def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 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))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -8294,8 +9673,10 @@ def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 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))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -8303,8 +9684,10 @@ def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 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))) + -- wf_uN: `%%`(32, `%`_uN($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* @@ -8415,273 +9798,452 @@ 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_ +relation fun_lpacknum_: `%%%`(lanetype, 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) + rule fun_lpacknum__case_0{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) + rule fun_lpacknum__case_1{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) + rule fun_lpacknum__case_2{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) + rule fun_lpacknum__case_3{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)) + rule fun_lpacknum__case_4{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)) + rule fun_lpacknum__case_5{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 -def $cpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ +relation fun_cpacknum_: `%%%`(storagetype, lit_, lit_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(I32_storagetype, c) = c + rule fun_cpacknum__case_0{c : lit_}: + `%%%`(I32_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(I64_storagetype, c) = c + rule fun_cpacknum__case_1{c : lit_}: + `%%%`(I64_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(F32_storagetype, c) = c + rule fun_cpacknum__case_2{c : lit_}: + `%%%`(F32_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(F64_storagetype, c) = c + rule fun_cpacknum__case_3{c : lit_}: + `%%%`(F64_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(V128_storagetype, c) = c + rule fun_cpacknum__case_4{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)) + rule fun_cpacknum__case_5{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)) + rule fun_cpacknum__case_6{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 -def $lunpacknum_(lanetype : lanetype, lane_ : lane_) : num_ +relation fun_lunpacknum_: `%%%`(lanetype, 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 + rule fun_lunpacknum__case_0{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 + rule fun_lunpacknum__case_1{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 + rule fun_lunpacknum__case_2{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 + rule fun_lunpacknum__case_3{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)) + rule fun_lunpacknum__case_4{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)) + rule fun_lunpacknum__case_5{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 -def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ +relation fun_cunpacknum_: `%%%`(storagetype, lit_, lit_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(I32_storagetype, c) = c + rule fun_cunpacknum__case_0{c : lit_}: + `%%%`(I32_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(I64_storagetype, c) = c + rule fun_cunpacknum__case_1{c : lit_}: + `%%%`(I64_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(F32_storagetype, c) = c + rule fun_cunpacknum__case_2{c : lit_}: + `%%%`(F32_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(F64_storagetype, c) = c + rule fun_cunpacknum__case_3{c : lit_}: + `%%%`(F64_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(V128_storagetype, c) = c + rule fun_cunpacknum__case_4{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)))) + rule fun_cunpacknum__case_5{c : uN, var_0 : consttype?}: + `%%%`(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)))) + -- fun_cunpack: `%%`($storagetype_packtype(I8_packtype), var_0) + -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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)))) + rule fun_cunpacknum__case_6{c : uN, var_0 : consttype?}: + `%%%`(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)))) + -- fun_cunpack: `%%`($storagetype_packtype(I16_packtype), var_0) + -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))) + 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) + -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, 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_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) + -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, var_0)) + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} ;; ../../../../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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))} + 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#30)*{iter_0#30 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- lift(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_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#32)*{iter_0#32 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- lift(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_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#34)*{iter_0#34 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- lift(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_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#36)*{iter_0#36 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- lift(var_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, 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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)))] + 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)))]) -- 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)))] + 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)))]) -- 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)))] + 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)))]) -- 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)))] + 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)))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $testop_(numtype : numtype, testop_ : testop_, num_ : num_) : u32 +relation fun_testop_: `%%%%`(numtype, testop_, 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) + rule fun_testop__case_0{i : uN, var_0 : u32}: + `%%%%`(I32_numtype, mk_testop__0_testop_(I32_Inn, EQZ_testop_Inn), mk_num__0_num_(I32_Inn, i), var_0) + -- fun_ieqz_: `%%%`($sizenn($numtype_addrtype(I32_Inn)), i, var_0) + ;; ../../../../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) + rule fun_testop__case_1{i : uN, var_0 : u32}: + `%%%%`(I64_numtype, mk_testop__0_testop_(I64_Inn, EQZ_testop_Inn), mk_num__0_num_(I64_Inn, i), var_0) + -- fun_ieqz_: `%%%`($sizenn($numtype_addrtype(I64_Inn)), i, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $relop_(numtype : numtype, relop_ : relop_, num_ : num_, num_ : num_) : u32 @@ -8735,121 +10297,192 @@ 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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))] + 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))]) -- 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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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))]) -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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__{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))]) -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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__{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))]) -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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__{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))]) -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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__{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))]) -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), 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__{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))]) -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), 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__{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))]) -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), 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__{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))]) -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) @@ -8860,202 +10493,392 @@ def $lanes_(shape : shape, vec_ : vec_) : lane_* 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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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#2833?{half#2833 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_16{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#2833?{half#2833 <- `half?`}, sx)), ?()) + ;; ../../../../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#2834?{half#2834 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_17{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#2834?{half#2834 <- `half?`}, sx)), ?()) + ;; ../../../../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#2835?{half#2835 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_18{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#2835?{half#2835 <- `half?`}, sx)), ?()) + ;; ../../../../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#2836?{half#2836 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_19{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#2836?{half#2836 <- `half?`}, sx)), ?()) + ;; ../../../../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#2837?{half#2837 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_20{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#2837?{half#2837 <- `half?`}, sx)), ?()) + ;; ../../../../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#2838?{half#2838 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_21{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#2838?{half#2838 <- `half?`}, sx)), ?()) + ;; ../../../../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#2839?{half#2839 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_22{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#2839?{half#2839 <- `half?`}, sx)), ?()) + ;; ../../../../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#2840?{half#2840 <- `half?`}, sx))) = ?() + rule fun_zeroop_case_23{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#2840?{half#2840 <- `half?`}, sx)), ?()) + ;; ../../../../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#3245?{zero#3245 <- `zero?`}))) = zero#3246?{zero#3246 <- `zero?`} + rule fun_zeroop_case_24{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#3245?{zero#3245 <- `zero?`})), zero#3246?{zero#3246 <- `zero?`}) + ;; ../../../../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#3247?{zero#3247 <- `zero?`}))) = zero#3248?{zero#3248 <- `zero?`} + rule fun_zeroop_case_25{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#3247?{zero#3247 <- `zero?`})), zero#3248?{zero#3248 <- `zero?`}) + ;; ../../../../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#3249?{zero#3249 <- `zero?`}))) = zero#3250?{zero#3250 <- `zero?`} + rule fun_zeroop_case_26{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#3249?{zero#3249 <- `zero?`})), zero#3250?{zero#3250 <- `zero?`}) + ;; ../../../../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#3251?{zero#3251 <- `zero?`}))) = zero#3252?{zero#3252 <- `zero?`} + rule fun_zeroop_case_27{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#3251?{zero#3251 <- `zero?`})), zero#3252?{zero#3252 <- `zero?`}) + ;; ../../../../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#3253?{zero#3253 <- `zero?`}))) = zero#3254?{zero#3254 <- `zero?`} + rule fun_zeroop_case_28{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#3253?{zero#3253 <- `zero?`})), zero#3254?{zero#3254 <- `zero?`}) + ;; ../../../../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#3255?{zero#3255 <- `zero?`}))) = zero#3256?{zero#3256 <- `zero?`} + rule fun_zeroop_case_29{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#3255?{zero#3255 <- `zero?`})), zero#3256?{zero#3256 <- `zero?`}) + ;; ../../../../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#3257?{zero#3257 <- `zero?`}))) = zero#3258?{zero#3258 <- `zero?`} + rule fun_zeroop_case_30{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#3257?{zero#3257 <- `zero?`})), zero#3258?{zero#3258 <- `zero?`}) + ;; ../../../../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#3259?{zero#3259 <- `zero?`}))) = zero#3260?{zero#3260 <- `zero?`} + rule fun_zeroop_case_31{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#3259?{zero#3259 <- `zero?`})), zero#3260?{zero#3260 <- `zero?`}) + ;; ../../../../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#3261?{zero#3261 <- `zero?`}))) = zero#3262?{zero#3262 <- `zero?`} + rule fun_zeroop_case_32{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#3261?{zero#3261 <- `zero?`})), zero#3262?{zero#3262 <- `zero?`}) + ;; ../../../../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#3263?{zero#3263 <- `zero?`}))) = zero#3264?{zero#3264 <- `zero?`} + rule fun_zeroop_case_33{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#3263?{zero#3263 <- `zero?`})), zero#3264?{zero#3264 <- `zero?`}) + ;; ../../../../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#3265?{zero#3265 <- `zero?`}))) = zero#3266?{zero#3266 <- `zero?`} + rule fun_zeroop_case_34{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#3265?{zero#3265 <- `zero?`})), zero#3266?{zero#3266 <- `zero?`}) + ;; ../../../../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#3267?{zero#3267 <- `zero?`}))) = zero#3268?{zero#3268 <- `zero?`} + rule fun_zeroop_case_35{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#3267?{zero#3267 <- `zero?`})), zero#3268?{zero#3268 <- `zero?`}) + ;; ../../../../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#3269?{zero#3269 <- `zero?`}))) = zero#3270?{zero#3270 <- `zero?`} + rule fun_zeroop_case_36{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#3269?{zero#3269 <- `zero?`})), zero#3270?{zero#3270 <- `zero?`}) + ;; ../../../../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#3271?{zero#3271 <- `zero?`}))) = zero#3272?{zero#3272 <- `zero?`} + rule fun_zeroop_case_37{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#3271?{zero#3271 <- `zero?`})), zero#3272?{zero#3272 <- `zero?`}) + ;; ../../../../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#3273?{zero#3273 <- `zero?`}))) = zero#3274?{zero#3274 <- `zero?`} + rule fun_zeroop_case_38{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#3273?{zero#3273 <- `zero?`})), zero#3274?{zero#3274 <- `zero?`}) + ;; ../../../../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#3275?{zero#3275 <- `zero?`}))) = zero#3276?{zero#3276 <- `zero?`} + rule fun_zeroop_case_39{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#3275?{zero#3275 <- `zero?`})), zero#3276?{zero#3276 <- `zero?`}) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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), ?()) + ;; ../../../../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}: + `%%%%`(`%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), ?()) + ;; ../../../../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}: + `%%%%`(`%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), ?()) + ;; ../../../../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}: + `%%%%`(`%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), ?()) ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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#2841?{half#2841 <- `half?`}, sx))) = half#2842?{half#2842 <- `half?`} + rule fun_halfop_case_16{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#2841?{half#2841 <- `half?`}, sx)), half#2842?{half#2842 <- `half?`}) + ;; ../../../../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#2843?{half#2843 <- `half?`}, sx))) = half#2844?{half#2844 <- `half?`} + rule fun_halfop_case_17{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#2843?{half#2843 <- `half?`}, sx)), half#2844?{half#2844 <- `half?`}) + ;; ../../../../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#2845?{half#2845 <- `half?`}, sx))) = half#2846?{half#2846 <- `half?`} + rule fun_halfop_case_18{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#2845?{half#2845 <- `half?`}, sx)), half#2846?{half#2846 <- `half?`}) + ;; ../../../../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#2847?{half#2847 <- `half?`}, sx))) = half#2848?{half#2848 <- `half?`} + rule fun_halfop_case_19{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#2847?{half#2847 <- `half?`}, sx)), half#2848?{half#2848 <- `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(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#2849?{half#2849 <- `half?`}, sx))) = half#2850?{half#2850 <- `half?`} + rule fun_halfop_case_20{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#2849?{half#2849 <- `half?`}, sx)), half#2850?{half#2850 <- `half?`}) + ;; ../../../../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#2851?{half#2851 <- `half?`}, sx))) = half#2852?{half#2852 <- `half?`} + rule fun_halfop_case_21{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#2851?{half#2851 <- `half?`}, sx)), half#2852?{half#2852 <- `half?`}) + ;; ../../../../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#2853?{half#2853 <- `half?`}, sx))) = half#2854?{half#2854 <- `half?`} + rule fun_halfop_case_22{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#2853?{half#2853 <- `half?`}, sx)), half#2854?{half#2854 <- `half?`}) + ;; ../../../../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#2855?{half#2855 <- `half?`}, sx))) = half#2856?{half#2856 <- `half?`} + rule fun_halfop_case_23{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#2855?{half#2855 <- `half?`}, sx)), half#2856?{half#2856 <- `half?`}) + ;; ../../../../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#3277?{zero#3277 <- `zero?`}))) = ?() + rule fun_halfop_case_24{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#3277?{zero#3277 <- `zero?`})), ?()) + ;; ../../../../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#3278?{zero#3278 <- `zero?`}))) = ?() + rule fun_halfop_case_25{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#3278?{zero#3278 <- `zero?`})), ?()) + ;; ../../../../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#3279?{zero#3279 <- `zero?`}))) = ?() + rule fun_halfop_case_26{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#3279?{zero#3279 <- `zero?`})), ?()) + ;; ../../../../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#3280?{zero#3280 <- `zero?`}))) = ?() + rule fun_halfop_case_27{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#3280?{zero#3280 <- `zero?`})), ?()) + ;; ../../../../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#3281?{zero#3281 <- `zero?`}))) = ?() + rule fun_halfop_case_28{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#3281?{zero#3281 <- `zero?`})), ?()) + ;; ../../../../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#3282?{zero#3282 <- `zero?`}))) = ?() + rule fun_halfop_case_29{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#3282?{zero#3282 <- `zero?`})), ?()) + ;; ../../../../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#3283?{zero#3283 <- `zero?`}))) = ?() + rule fun_halfop_case_30{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#3283?{zero#3283 <- `zero?`})), ?()) + ;; ../../../../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#3284?{zero#3284 <- `zero?`}))) = ?() + rule fun_halfop_case_31{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#3284?{zero#3284 <- `zero?`})), ?()) + ;; ../../../../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#3285?{zero#3285 <- `zero?`}))) = ?() + rule fun_halfop_case_32{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#3285?{zero#3285 <- `zero?`})), ?()) + ;; ../../../../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#3286?{zero#3286 <- `zero?`}))) = ?() + rule fun_halfop_case_33{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#3286?{zero#3286 <- `zero?`})), ?()) + ;; ../../../../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#3287?{zero#3287 <- `zero?`}))) = ?() + rule fun_halfop_case_34{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#3287?{zero#3287 <- `zero?`})), ?()) + ;; ../../../../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#3288?{zero#3288 <- `zero?`}))) = ?() + rule fun_halfop_case_35{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#3288?{zero#3288 <- `zero?`})), ?()) + ;; ../../../../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#3289?{zero#3289 <- `zero?`}))) = ?() + rule fun_halfop_case_36{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#3289?{zero#3289 <- `zero?`})), ?()) + ;; ../../../../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#3290?{zero#3290 <- `zero?`}))) = ?() + rule fun_halfop_case_37{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#3290?{zero#3290 <- `zero?`})), ?()) + ;; ../../../../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#3291?{zero#3291 <- `zero?`}))) = ?() + rule fun_halfop_case_38{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#3291?{zero#3291 <- `zero?`})), ?()) + ;; ../../../../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#3292?{zero#3292 <- `zero?`}))) = ?() + rule fun_halfop_case_39{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#3292?{zero#3292 <- `zero?`})), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $half(half : half, nat : nat, nat : nat) : nat @@ -9073,8 +10896,9 @@ def $iswizzle_lane_(N : N, iN*, iN : iN) : iN ;; ../../../../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*`}|)]))) + 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*`}|)]))) -- wf_uN: `%%`(N, `%`_uN(0)) + -- 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_* @@ -9472,33 +11296,40 @@ def $ivshiftopsx_(shape : shape, def $f_(N : N, sx : sx, iN : iN, u32 : u32) : i -- if (c#133*{c#133 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#132)), i)*{c_1#132 <- `c_1*`}) ;; ../../../../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, `c_1*` : lane_*}(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_0{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) -- 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#133)), `%`_iN(0))).0)))*{c_1#133 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) -- if (c_1#134*{c_1#134 <- `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#135)), `%`_iN(0))).0)*{c_1#135 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_1{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) -- 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#136)), `%`_iN(0))).0)))*{c_1#136 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) -- if (c_1#137*{c_1#137 <- `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#138)), `%`_iN(0))).0)*{c_1#138 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_2{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) -- 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#139)), `%`_iN(0))).0)))*{c_1#139 <- `c_1*`} -- wf_bit: `%`(`%`_bit(0)) -- if (c_1#140*{c_1#140 <- `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#141)), `%`_iN(0))).0)*{c_1#141 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_3{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) -- 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#142)), `%`_iN(0))).0)))*{c_1#142 <- `c_1*`} @@ -9546,9 +11377,10 @@ def $ivswizzlop_(shape : shape, def $f_(N : N, iN*, iN : iN) : iN, vec_ : vec_, -- if (c#145*{c#145 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#156))*{c_1#156 <- `c_1*`}, !($proj_lane__2(c_2#102)))*{c_2#102 <- `c_2*`}) ;; ../../../../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, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#128389*{i#128389 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#149*{c#149 <- `c*`}) + rule fun_ivshufflop__case_0{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#128389*{i#128389 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#149*{c#149 <- `c*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c#147))*{c#147 <- `c*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#157))*{c_1#157 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#103))*{c_2#103 <- `c_2*`} @@ -9556,8 +11388,10 @@ def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ -- if (c_1#158*{c_1#158 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) -- if (c_2#104*{c_2#104 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) -- if (c#148*{c#148 <- `c*`} = c_1#159*{c_1#159 <- `c_1*`} ++ c_2#105*{c_2#105 <- `c_2*`}[$proj_uN_0(i#128396).0]*{i#128396 <- `i*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#128399*{i#128399 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#152*{c#152 <- `c*`}) + rule fun_ivshufflop__case_1{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#128399*{i#128399 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#152*{c#152 <- `c*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c#150))*{c#150 <- `c*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#160))*{c_1#160 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#106))*{c_2#106 <- `c_2*`} @@ -9565,8 +11399,10 @@ def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ -- if (c_1#161*{c_1#161 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) -- if (c_2#107*{c_2#107 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) -- if (c#151*{c#151 <- `c*`} = c_1#162*{c_1#162 <- `c_1*`} ++ c_2#108*{c_2#108 <- `c_2*`}[$proj_uN_0(i#128406).0]*{i#128406 <- `i*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#128409*{i#128409 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#155*{c#155 <- `c*`}) + rule fun_ivshufflop__case_2{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#128409*{i#128409 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#155*{c#155 <- `c*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c#153))*{c#153 <- `c*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#163))*{c_1#163 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#109))*{c_2#109 <- `c_2*`} @@ -9574,8 +11410,10 @@ def $ivshufflop_(shape : shape, laneidx*, vec_ : vec_, vec_ : vec_) : vec_ -- if (c_1#164*{c_1#164 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) -- if (c_2#110*{c_2#110 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) -- if (c#154*{c#154 <- `c*`} = c_1#165*{c_1#165 <- `c_1*`} ++ c_2#111*{c_2#111 <- `c_2*`}[$proj_uN_0(i#128416).0]*{i#128416 <- `i*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#128419*{i#128419 <- `i*`}, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#158*{c#158 <- `c*`}) + rule fun_ivshufflop__case_3{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#128419*{i#128419 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#158*{c#158 <- `c*`})) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c#156))*{c#156 <- `c*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#166))*{c_1#166 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#112))*{c_2#112 <- `c_2*`} @@ -9606,795 +11444,1239 @@ 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) + rule fun_vunop__case_0{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))) + ;; ../../../../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) + rule fun_vunop__case_1{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))) + ;; ../../../../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) + rule fun_vunop__case_2{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))) + ;; ../../../../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) + rule fun_vunop__case_3{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))) + ;; ../../../../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) + rule fun_vunop__case_4{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))) + ;; ../../../../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) + rule fun_vunop__case_5{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))) + ;; ../../../../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) + rule fun_vunop__case_6{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))) + ;; ../../../../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) + rule fun_vunop__case_7{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))) + ;; ../../../../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) + rule fun_vunop__case_8{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))) + ;; ../../../../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) + rule fun_vunop__case_9{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))) + ;; ../../../../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) + rule fun_vunop__case_10{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))) + ;; ../../../../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) + rule fun_vunop__case_11{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))) + ;; ../../../../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) + rule fun_vunop__case_12{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))) + ;; ../../../../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) + rule fun_vunop__case_13{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))) + ;; ../../../../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) + rule fun_vunop__case_14{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))) + ;; ../../../../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) + rule fun_vunop__case_15{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))) + ;; ../../../../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) + rule fun_vunop__case_16{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))) + ;; ../../../../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) + rule fun_vunop__case_17{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))) + ;; ../../../../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) + rule fun_vunop__case_18{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))) + ;; ../../../../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) + rule fun_vunop__case_19{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))) + ;; ../../../../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) + rule fun_vunop__case_20{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))) + ;; ../../../../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) + rule fun_vunop__case_21{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))) + ;; ../../../../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) + rule fun_vunop__case_22{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))) + ;; ../../../../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) + rule fun_vunop__case_23{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))) + ;; ../../../../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) + rule fun_vunop__case_24{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))) + ;; ../../../../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) + rule fun_vunop__case_25{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))) ;; ../../../../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) + rule fun_vbinop__case_0{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))) + ;; ../../../../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) + rule fun_vbinop__case_1{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))) + ;; ../../../../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) + rule fun_vbinop__case_2{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))) + ;; ../../../../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) + rule fun_vbinop__case_3{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))) + ;; ../../../../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) + rule fun_vbinop__case_4{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))) + ;; ../../../../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) + rule fun_vbinop__case_5{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))) + ;; ../../../../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) + rule fun_vbinop__case_6{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))) + ;; ../../../../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) + rule fun_vbinop__case_7{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))) + ;; ../../../../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) + rule fun_vbinop__case_8{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))) + ;; ../../../../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) + rule fun_vbinop__case_9{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))) + ;; ../../../../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) + rule fun_vbinop__case_10{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))) + ;; ../../../../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) + rule fun_vbinop__case_11{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))) + ;; ../../../../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) + rule fun_vbinop__case_12{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))) + ;; ../../../../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) + rule fun_vbinop__case_13{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))) + ;; ../../../../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) + rule fun_vbinop__case_14{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))) + ;; ../../../../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) + rule fun_vbinop__case_15{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))) + ;; ../../../../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) + rule fun_vbinop__case_16{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))) + ;; ../../../../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) + rule fun_vbinop__case_17{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))) + ;; ../../../../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) + rule fun_vbinop__case_18{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))) + ;; ../../../../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) + rule fun_vbinop__case_19{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))) + ;; ../../../../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) + rule fun_vbinop__case_20{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))) + ;; ../../../../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) + rule fun_vbinop__case_21{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))) + ;; ../../../../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) + rule fun_vbinop__case_22{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))) + ;; ../../../../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) + rule fun_vbinop__case_23{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))) + ;; ../../../../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) + rule fun_vbinop__case_24{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))) + ;; ../../../../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) + rule fun_vbinop__case_25{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))) + ;; ../../../../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) + rule fun_vbinop__case_26{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))) + ;; ../../../../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) + rule fun_vbinop__case_27{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))) + ;; ../../../../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) + rule fun_vbinop__case_28{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))) + ;; ../../../../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) + rule fun_vbinop__case_29{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))) + ;; ../../../../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) + rule fun_vbinop__case_30{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))) + ;; ../../../../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) + rule fun_vbinop__case_31{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))) + ;; ../../../../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) + rule fun_vbinop__case_32{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))) + ;; ../../../../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) + rule fun_vbinop__case_33{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))) + ;; ../../../../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) + rule fun_vbinop__case_34{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))) + ;; ../../../../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) + rule fun_vbinop__case_35{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))) + ;; ../../../../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) + rule fun_vbinop__case_36{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))) + ;; ../../../../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) + rule fun_vbinop__case_37{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))) + ;; ../../../../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) + rule fun_vbinop__case_38{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))) + ;; ../../../../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) + rule fun_vbinop__case_39{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))) + ;; ../../../../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) + rule fun_vbinop__case_40{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))) + ;; ../../../../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) + rule fun_vbinop__case_41{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))) + ;; ../../../../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) + rule fun_vbinop__case_42{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))) + ;; ../../../../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) + rule fun_vbinop__case_43{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))) + ;; ../../../../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) + rule fun_vbinop__case_44{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))) + ;; ../../../../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) + rule fun_vbinop__case_45{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))) + ;; ../../../../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) + rule fun_vbinop__case_46{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))) + ;; ../../../../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) + rule fun_vbinop__case_47{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))) + ;; ../../../../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) + rule fun_vbinop__case_48{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))) + ;; ../../../../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) + rule fun_vbinop__case_49{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))) + ;; ../../../../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) + rule fun_vbinop__case_50{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))) + ;; ../../../../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) + rule fun_vbinop__case_51{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))) + ;; ../../../../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) + rule fun_vbinop__case_52{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))) + ;; ../../../../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) + rule fun_vbinop__case_53{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))) + ;; ../../../../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) + rule fun_vbinop__case_54{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))) + ;; ../../../../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) + rule fun_vbinop__case_55{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))) + ;; ../../../../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) + rule fun_vbinop__case_56{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))) + ;; ../../../../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) + rule fun_vbinop__case_57{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))) + ;; ../../../../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) + rule fun_vbinop__case_58{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))) + ;; ../../../../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) + rule fun_vbinop__case_59{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))) ;; ../../../../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) + rule fun_vternop__case_0{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))) + ;; ../../../../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) + rule fun_vternop__case_1{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))) + ;; ../../../../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) + rule fun_vternop__case_2{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))) + ;; ../../../../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) + rule fun_vternop__case_3{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))) + ;; ../../../../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) + rule fun_vternop__case_4{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))) + ;; ../../../../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) + rule fun_vternop__case_5{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))) + ;; ../../../../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) + rule fun_vternop__case_6{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))) + ;; ../../../../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) + rule fun_vternop__case_7{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))) ;; ../../../../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) + rule fun_vrelop__case_0{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))) + ;; ../../../../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) + rule fun_vrelop__case_1{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))) + ;; ../../../../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) + rule fun_vrelop__case_2{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))) + ;; ../../../../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) + rule fun_vrelop__case_3{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))) + ;; ../../../../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) + rule fun_vrelop__case_4{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))) + ;; ../../../../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) + rule fun_vrelop__case_5{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))) + ;; ../../../../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) + rule fun_vrelop__case_6{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))) + ;; ../../../../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) + rule fun_vrelop__case_7{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))) + ;; ../../../../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) + rule fun_vrelop__case_8{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))) + ;; ../../../../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) + rule fun_vrelop__case_9{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))) + ;; ../../../../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) + rule fun_vrelop__case_10{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))) + ;; ../../../../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) + rule fun_vrelop__case_11{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))) + ;; ../../../../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) + rule fun_vrelop__case_12{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))) + ;; ../../../../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) + rule fun_vrelop__case_13{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))) + ;; ../../../../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) + rule fun_vrelop__case_14{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))) + ;; ../../../../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) + rule fun_vrelop__case_15{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))) + ;; ../../../../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) + rule fun_vrelop__case_16{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))) + ;; ../../../../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) + rule fun_vrelop__case_17{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))) + ;; ../../../../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) + rule fun_vrelop__case_18{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))) + ;; ../../../../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) + rule fun_vrelop__case_19{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))) + ;; ../../../../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) + rule fun_vrelop__case_20{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))) + ;; ../../../../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) + rule fun_vrelop__case_21{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))) + ;; ../../../../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) + rule fun_vrelop__case_22{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))) + ;; ../../../../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) + rule fun_vrelop__case_23{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))) + ;; ../../../../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) + rule fun_vrelop__case_24{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))) + ;; ../../../../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) + rule fun_vrelop__case_25{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))) + ;; ../../../../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) + rule fun_vrelop__case_26{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))) + ;; ../../../../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) + rule fun_vrelop__case_27{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))) + ;; ../../../../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) + rule fun_vrelop__case_28{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))) + ;; ../../../../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) + rule fun_vrelop__case_29{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))) + ;; ../../../../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) + rule fun_vrelop__case_30{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))) + ;; ../../../../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) + rule fun_vrelop__case_31{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))) + ;; ../../../../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) + rule fun_vrelop__case_32{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))) + ;; ../../../../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) + rule fun_vrelop__case_33{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))) + ;; ../../../../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) + rule fun_vrelop__case_34{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))) + ;; ../../../../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) + rule fun_vrelop__case_35{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))) ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, half : half, sx : sx, c_1 : uN, c : 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, c : 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)]) -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, c : fN}(`%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#2857?{half#2857 <- `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, c : fN}: + `%%%%%`(`%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#2857?{half#2857 <- `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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, c : fN}(`%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#2858?{half#2858 <- `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, c : fN}: + `%%%%%`(`%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#2858?{half#2858 <- `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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, c : fN}(`%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#2859?{half#2859 <- `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, c : fN}: + `%%%%%`(`%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#2859?{half#2859 <- `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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, c : fN}(`%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#2860?{half#2860 <- `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, c : fN}: + `%%%%%`(`%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#2860?{half#2860 <- `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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, c : fN}(`%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#2861?{half#2861 <- `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, c : fN}: + `%%%%%`(`%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#2861?{half#2861 <- `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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, c : fN}(`%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#2862?{half#2862 <- `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, c : fN}: + `%%%%%`(`%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#2862?{half#2862 <- `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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, c : fN}(`%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#2863?{half#2863 <- `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, c : fN}: + `%%%%%`(`%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#2863?{half#2863 <- `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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, `half?` : half?, sx : sx, c_1 : uN, c : fN}(`%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#2864?{half#2864 <- `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, c : fN}: + `%%%%%`(`%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#2864?{half#2864 <- `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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3293?{zero#3293 <- `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#161))?{c#161 <- `c?`}) + rule fun_lcvtop___case_24{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3293?{zero#3293 <- `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#161))?{c#161 <- `c?`})) -- (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#159))))?{c#159 <- `c?`} -- if (c#160?{c#160 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3294?{zero#3294 <- `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#164))?{c#164 <- `c?`}) + rule fun_lcvtop___case_25{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3294?{zero#3294 <- `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#164))?{c#164 <- `c?`})) -- (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#162))))?{c#162 <- `c?`} -- if (c#163?{c#163 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3295?{zero#3295 <- `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#167))?{c#167 <- `c?`}) + rule fun_lcvtop___case_26{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3295?{zero#3295 <- `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#167))?{c#167 <- `c?`})) -- (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#165))))?{c#165 <- `c?`} -- if (c#166?{c#166 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3296?{zero#3296 <- `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#170))?{c#170 <- `c?`}) + rule fun_lcvtop___case_27{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3296?{zero#3296 <- `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#170))?{c#170 <- `c?`})) -- (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#168))))?{c#168 <- `c?`} -- if (c#169?{c#169 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3297?{zero#3297 <- `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#173))?{c#173 <- `c?`}) + rule fun_lcvtop___case_28{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3297?{zero#3297 <- `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#173))?{c#173 <- `c?`})) -- (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#171))))?{c#171 <- `c?`} -- if (c#172?{c#172 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3298?{zero#3298 <- `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#176))?{c#176 <- `c?`}) + rule fun_lcvtop___case_29{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3298?{zero#3298 <- `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#176))?{c#176 <- `c?`})) -- (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#174))))?{c#174 <- `c?`} -- if (c#175?{c#175 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3299?{zero#3299 <- `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#179))?{c#179 <- `c?`}) + rule fun_lcvtop___case_30{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3299?{zero#3299 <- `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#179))?{c#179 <- `c?`})) -- (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#177))))?{c#177 <- `c?`} -- if (c#178?{c#178 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3300?{zero#3300 <- `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#182))?{c#182 <- `c?`}) + rule fun_lcvtop___case_31{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3300?{zero#3300 <- `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#182))?{c#182 <- `c?`})) -- (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#180))))?{c#180 <- `c?`} -- if (c#181?{c#181 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3301?{zero#3301 <- `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#185))?{c#185 <- `c?`}) + rule fun_lcvtop___case_32{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3301?{zero#3301 <- `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#185))?{c#185 <- `c?`})) -- (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#183))))?{c#183 <- `c?`} -- if (c#184?{c#184 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3302?{zero#3302 <- `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#188))?{c#188 <- `c?`}) + rule fun_lcvtop___case_33{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3302?{zero#3302 <- `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#188))?{c#188 <- `c?`})) -- (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#186))))?{c#186 <- `c?`} -- if (c#187?{c#187 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3303?{zero#3303 <- `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#191))?{c#191 <- `c?`}) + rule fun_lcvtop___case_34{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3303?{zero#3303 <- `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#191))?{c#191 <- `c?`})) -- (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#189))))?{c#189 <- `c?`} -- if (c#190?{c#190 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3304?{zero#3304 <- `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#194))?{c#194 <- `c?`}) + rule fun_lcvtop___case_35{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3304?{zero#3304 <- `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#194))?{c#194 <- `c?`})) -- (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#192))))?{c#192 <- `c?`} -- if (c#193?{c#193 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3305?{zero#3305 <- `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#197))?{c#197 <- `c?`}) + rule fun_lcvtop___case_36{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3305?{zero#3305 <- `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#197))?{c#197 <- `c?`})) -- (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#195))))?{c#195 <- `c?`} -- if (c#196?{c#196 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3306?{zero#3306 <- `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#200))?{c#200 <- `c?`}) + rule fun_lcvtop___case_37{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3306?{zero#3306 <- `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#200))?{c#200 <- `c?`})) -- (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#198))))?{c#198 <- `c?`} -- if (c#199?{c#199 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3307?{zero#3307 <- `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#203))?{c#203 <- `c?`}) + rule fun_lcvtop___case_38{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3307?{zero#3307 <- `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#203))?{c#203 <- `c?`})) -- (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#201))))?{c#201 <- `c?`} -- if (c#202?{c#202 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3308?{zero#3308 <- `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#206))?{c#206 <- `c?`}) + rule fun_lcvtop___case_39{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3308?{zero#3308 <- `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#206))?{c#206 <- `c?`})) -- (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#204))))?{c#204 <- `c?`} -- if (c#205?{c#205 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3309?{zero#3309 <- `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#209))?{c#209 <- `c?`}) + rule fun_lcvtop___case_40{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3309?{zero#3309 <- `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#209))?{c#209 <- `c?`})) -- (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#207))))?{c#207 <- `c?`} -- if (c#208?{c#208 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3310?{zero#3310 <- `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#212))?{c#212 <- `c?`}) + rule fun_lcvtop___case_41{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3310?{zero#3310 <- `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#212))?{c#212 <- `c?`})) -- (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#210))))?{c#210 <- `c?`} -- if (c#211?{c#211 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3311?{zero#3311 <- `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#215))?{c#215 <- `c?`}) + rule fun_lcvtop___case_42{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3311?{zero#3311 <- `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#215))?{c#215 <- `c?`})) -- (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#213))))?{c#213 <- `c?`} -- if (c#214?{c#214 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3312?{zero#3312 <- `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#218))?{c#218 <- `c?`}) + rule fun_lcvtop___case_43{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3312?{zero#3312 <- `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#218))?{c#218 <- `c?`})) -- (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#216))))?{c#216 <- `c?`} -- if (c#217?{c#217 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3313?{zero#3313 <- `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#221))?{c#221 <- `c?`}) + rule fun_lcvtop___case_44{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3313?{zero#3313 <- `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#221))?{c#221 <- `c?`})) -- (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#219))))?{c#219 <- `c?`} -- if (c#220?{c#220 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3314?{zero#3314 <- `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#224))?{c#224 <- `c?`}) + rule fun_lcvtop___case_45{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3314?{zero#3314 <- `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#224))?{c#224 <- `c?`})) -- (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#222))))?{c#222 <- `c?`} -- if (c#223?{c#223 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3315?{zero#3315 <- `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#227))?{c#227 <- `c?`}) + rule fun_lcvtop___case_46{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3315?{zero#3315 <- `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#227))?{c#227 <- `c?`})) -- (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#225))))?{c#225 <- `c?`} -- if (c#226?{c#226 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3316?{zero#3316 <- `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#230))?{c#230 <- `c?`}) + rule fun_lcvtop___case_47{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3316?{zero#3316 <- `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#230))?{c#230 <- `c?`})) -- (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#228))))?{c#228 <- `c?`} -- if (c#229?{c#229 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3317?{zero#3317 <- `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#233))?{c#233 <- `c?`}) + rule fun_lcvtop___case_48{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3317?{zero#3317 <- `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#233))?{c#233 <- `c?`})) -- (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#231))))?{c#231 <- `c?`} -- if (c#232?{c#232 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3318?{zero#3318 <- `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#236))?{c#236 <- `c?`}) + rule fun_lcvtop___case_49{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3318?{zero#3318 <- `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#236))?{c#236 <- `c?`})) -- (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#234))))?{c#234 <- `c?`} -- if (c#235?{c#235 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3319?{zero#3319 <- `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#239))?{c#239 <- `c?`}) + rule fun_lcvtop___case_50{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3319?{zero#3319 <- `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#239))?{c#239 <- `c?`})) -- (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#237))))?{c#237 <- `c?`} -- if (c#238?{c#238 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3320?{zero#3320 <- `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#242))?{c#242 <- `c?`}) + rule fun_lcvtop___case_51{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3320?{zero#3320 <- `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#242))?{c#242 <- `c?`})) -- (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#240))))?{c#240 <- `c?`} -- if (c#241?{c#241 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3321?{zero#3321 <- `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#245))?{c#245 <- `c?`}) + rule fun_lcvtop___case_52{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3321?{zero#3321 <- `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#245))?{c#245 <- `c?`})) -- (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#243))))?{c#243 <- `c?`} -- if (c#244?{c#244 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3322?{zero#3322 <- `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#248))?{c#248 <- `c?`}) + rule fun_lcvtop___case_53{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3322?{zero#3322 <- `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#248))?{c#248 <- `c?`})) -- (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#246))))?{c#246 <- `c?`} -- if (c#247?{c#247 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3323?{zero#3323 <- `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#251))?{c#251 <- `c?`}) + rule fun_lcvtop___case_54{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3323?{zero#3323 <- `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#251))?{c#251 <- `c?`})) -- (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#249))))?{c#249 <- `c?`} -- if (c#250?{c#250 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}(`%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#3324?{zero#3324 <- `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#254))?{c#254 <- `c?`}) + rule fun_lcvtop___case_55{M_1 : nat, M_2 : nat, sx : sx, `zero?` : zero?, c_1 : fN, `c?` : iN?}: + `%%%%%`(`%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#3324?{zero#3324 <- `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#254))?{c#254 <- `c?`})) -- (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#252))))?{c#252 <- `c?`} -- if (c#253?{c#253 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#257))*{c#257 <- `c*`} + rule fun_lcvtop___case_56{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#257))*{c#257 <- `c*`}) -- (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#255))))*{c#255 <- `c*`} -- if (c#256*{c#256 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#260))*{c#260 <- `c*`} + rule fun_lcvtop___case_57{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#260))*{c#260 <- `c*`}) -- (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#258))))*{c#258 <- `c*`} -- if (c#259*{c#259 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#263))*{c#263 <- `c*`} + rule fun_lcvtop___case_58{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#263))*{c#263 <- `c*`}) -- (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#261))))*{c#261 <- `c*`} -- if (c#262*{c#262 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#266))*{c#266 <- `c*`} + rule fun_lcvtop___case_59{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#266))*{c#266 <- `c*`}) -- (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#264))))*{c#264 <- `c*`} -- if (c#265*{c#265 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#269))*{c#269 <- `c*`} + rule fun_lcvtop___case_60{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#269))*{c#269 <- `c*`}) -- (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#267))))*{c#267 <- `c*`} -- if (c#268*{c#268 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#272))*{c#272 <- `c*`} + rule fun_lcvtop___case_61{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#272))*{c#272 <- `c*`}) -- (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#270))))*{c#270 <- `c*`} -- if (c#271*{c#271 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#275))*{c#275 <- `c*`} + rule fun_lcvtop___case_62{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#275))*{c#275 <- `c*`}) -- (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#273))))*{c#273 <- `c*`} -- if (c#274*{c#274 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#278))*{c#278 <- `c*`} + rule fun_lcvtop___case_63{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#278))*{c#278 <- `c*`}) -- (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#276))))*{c#276 <- `c*`} -- if (c#277*{c#277 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#281))*{c#281 <- `c*`} + rule fun_lcvtop___case_64{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#281))*{c#281 <- `c*`}) -- (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#279))))*{c#279 <- `c*`} -- if (c#280*{c#280 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#284))*{c#284 <- `c*`} + rule fun_lcvtop___case_65{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#284))*{c#284 <- `c*`}) -- (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#282))))*{c#282 <- `c*`} -- if (c#283*{c#283 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#287))*{c#287 <- `c*`} + rule fun_lcvtop___case_66{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#287))*{c#287 <- `c*`}) -- (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#285))))*{c#285 <- `c*`} -- if (c#286*{c#286 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#290))*{c#290 <- `c*`} + rule fun_lcvtop___case_67{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#290))*{c#290 <- `c*`}) -- (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#288))))*{c#288 <- `c*`} -- if (c#289*{c#289 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#293))*{c#293 <- `c*`} + rule fun_lcvtop___case_68{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#293))*{c#293 <- `c*`}) -- (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#291))))*{c#291 <- `c*`} -- if (c#292*{c#292 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#296))*{c#296 <- `c*`} + rule fun_lcvtop___case_69{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#296))*{c#296 <- `c*`}) -- (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#294))))*{c#294 <- `c*`} -- if (c#295*{c#295 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#299))*{c#299 <- `c*`} + rule fun_lcvtop___case_70{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#299))*{c#299 <- `c*`}) -- (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#297))))*{c#297 <- `c*`} -- if (c#298*{c#298 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#302))*{c#302 <- `c*`} + rule fun_lcvtop___case_71{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#302))*{c#302 <- `c*`}) -- (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#300))))*{c#300 <- `c*`} -- if (c#301*{c#301 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1) = v + rule fun_vcvtop___case_0{Lnn_1 : lanetype, M : nat, Lnn_2 : lanetype, vcvtop : vcvtop__, v_1 : uN, v : uN, `c_1*` : lane_*, `c**` : lane_**, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1, v) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M))), c_1#169))*{c_1#169 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#303))*{c#303 <- `c*#43`}*{`c*#43` <- `c**`} -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) - -- 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) = ?())) + -- if ((var_0 = ?()) /\ (var_1 = ?())) -- if (c_1#170*{c_1#170 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1)) - -- if (c#304*{c#304 <- `c*#44`}*{`c*#44` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171)*{c_1#171 <- `c_1*`})) + -- if (c#304*{c#304 <- `c*#44`}*{`c*#44` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`})) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}) + ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v + 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, `c_1*` : lane_*, `c**` : lane_**, `var_1*` : lane_**, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `c_1*`} + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#172))*{c_1#172 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#306))*{c#306 <- `c*#46`}*{`c*#46` <- `c**`} -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(half)) + -- if (var_0 = ?(half)) -- if (c_1#173*{c_1#173 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2]) - -- if (c#307*{c#307 <- `c*#47`}*{`c*#47` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174)*{c_1#174 <- `c_1*`})) + -- if (c#307*{c#307 <- `c*#47`}*{`c*#47` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`})) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}) + ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v + rule fun_vcvtop___case_2{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, `c_1*` : lane_*, `c**` : lane_**, var_2 : lane_, `var_1*` : lane_**, var_0 : zero?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- fun_zero: `%%`(Lnn_2, var_2) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `c_1*`} + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#175))*{c_1#175 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#309))*{c#309 <- `c*#49`}*{`c*#49` <- `c**`} -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) + -- if (var_0 = ?(ZERO_zero)) -- if (c_1#176*{c_1#176 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)) - -- if (c#310*{c#310 <- `c*#50`}*{`c*#50` <- `c**`} = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177)*{c_1#177 <- `c_1*`} ++ [$zero(Lnn_2)]^M_1{})) + -- if (c#310*{c#310 <- `c*#50`}*{`c*#50` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [var_2]^M_1{})) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}) ;; ../../../../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) + rule fun_vshiftop__case_0{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))) + ;; ../../../../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) + rule fun_vshiftop__case_1{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))) + ;; ../../../../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) + rule fun_vshiftop__case_2{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))) + ;; ../../../../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) + rule fun_vshiftop__case_3{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))) + ;; ../../../../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) + rule fun_vshiftop__case_4{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))) + ;; ../../../../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) + rule fun_vshiftop__case_5{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))) + ;; ../../../../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) + rule fun_vshiftop__case_6{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))) + ;; ../../../../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) + rule fun_vshiftop__case_7{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))) ;; ../../../../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) + 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) -- 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) + 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) -- 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) + 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) -- 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) + 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) -- 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_ +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) + rule fun_vswizzlop__case_0{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) + rule fun_vswizzlop__case_1{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_ +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#129110*{i#129110 <- `i*`}, v_1, v_2) = $ivshufflop_(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2) + 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#129110*{i#129110 <- `i*`}, v_1, v_2, var_0) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) -- 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_ +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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#178))*{c_1#178 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#115))*{c_2#115 <- `c_2*`} @@ -10407,8 +12689,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#2*{c'_1#2 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- `c_1*`}) -- if (c'_2#2*{c'_2#2 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#117)))*{c_2#117 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#3)*{c'_1#3 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#181))*{c_1#181 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#118))*{c_2#118 <- `c_2*`} @@ -10421,8 +12705,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#5*{c'_1#5 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#183)))*{c_1#183 <- `c_1*`}) -- if (c'_2#5*{c'_2#5 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#120)))*{c_2#120 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#6)*{c'_1#6 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#184))*{c_1#184 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#121))*{c_2#121 <- `c_2*`} @@ -10435,8 +12721,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#8*{c'_1#8 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- `c_1*`}) -- if (c'_2#8*{c'_2#8 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#123)))*{c_2#123 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#9)*{c'_1#9 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#187))*{c_1#187 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#124))*{c_2#124 <- `c_2*`} @@ -10449,8 +12737,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#11*{c'_1#11 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#189)))*{c_1#189 <- `c_1*`}) -- if (c'_2#11*{c'_2#11 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#126)))*{c_2#126 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#12)*{c'_1#12 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#190))*{c_1#190 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#127))*{c_2#127 <- `c_2*`} @@ -10463,8 +12753,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#14*{c'_1#14 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- `c_1*`}) -- if (c'_2#14*{c'_2#14 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#129)))*{c_2#129 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#15)*{c'_1#15 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#193))*{c_1#193 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#130))*{c_2#130 <- `c_2*`} @@ -10477,8 +12769,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#17*{c'_1#17 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#195)))*{c_1#195 <- `c_1*`}) -- if (c'_2#17*{c'_2#17 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#132)))*{c_2#132 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#18)*{c'_1#18 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#196))*{c_1#196 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#133))*{c_2#133 <- `c_2*`} @@ -10491,8 +12785,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#20*{c'_1#20 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- `c_1*`}) -- if (c'_2#20*{c'_2#20 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#135)))*{c_2#135 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#21)*{c'_1#21 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#199))*{c_1#199 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#136))*{c_2#136 <- `c_2*`} @@ -10505,8 +12801,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#23*{c'_1#23 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#201)))*{c_1#201 <- `c_1*`}) -- if (c'_2#23*{c'_2#23 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#138)))*{c_2#138 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#24)*{c'_1#24 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#202))*{c_1#202 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#139))*{c_2#139 <- `c_2*`} @@ -10519,8 +12817,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#26*{c'_1#26 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- `c_1*`}) -- if (c'_2#26*{c'_2#26 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#141)))*{c_2#141 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#27)*{c'_1#27 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#205))*{c_1#205 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#142))*{c_2#142 <- `c_2*`} @@ -10533,8 +12833,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#29*{c'_1#29 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#207)))*{c_1#207 <- `c_1*`}) -- if (c'_2#29*{c'_2#29 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#144)))*{c_2#144 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#30)*{c'_1#30 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#208))*{c_1#208 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#145))*{c_2#145 <- `c_2*`} @@ -10547,8 +12849,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#32*{c'_1#32 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- `c_1*`}) -- if (c'_2#32*{c'_2#32 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#147)))*{c_2#147 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#33)*{c'_1#33 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#211))*{c_1#211 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#148))*{c_2#148 <- `c_2*`} @@ -10561,8 +12865,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#35*{c'_1#35 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#213)))*{c_1#213 <- `c_1*`}) -- if (c'_2#35*{c'_2#35 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#150)))*{c_2#150 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#36)*{c'_1#36 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#214))*{c_1#214 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#151))*{c_2#151 <- `c_2*`} @@ -10575,8 +12881,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#38*{c'_1#38 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#216)))*{c_1#216 <- `c_1*`}) -- if (c'_2#38*{c'_2#38 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#153)))*{c_2#153 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#39)*{c'_1#39 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#217))*{c_1#217 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#154))*{c_2#154 <- `c_2*`} @@ -10589,8 +12897,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#41*{c'_1#41 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#219)))*{c_1#219 <- `c_1*`}) -- if (c'_2#41*{c'_2#41 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#156)))*{c_2#156 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#42)*{c'_1#42 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#220))*{c_1#220 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#157))*{c_2#157 <- `c_2*`} @@ -10603,8 +12913,10 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, sx : sx, vec_ : vec_, vec_ : -- if (c'_1#44*{c'_1#44 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#222)))*{c_1#222 <- `c_1*`}) -- if (c'_2#44*{c'_2#44 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#159)))*{c_2#159 <- `c_2*`}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#45)*{c'_1#45 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#223))*{c_1#223 <- `c_1*`} -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#160))*{c_2#160 <- `c_2*`} @@ -10790,69 +13102,100 @@ def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(N : N, iN*) : iN*, sx -- if (c#358*{c#358 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#96*{c'_1#96 <- `c'_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) + rule fun_vextunop___case_0{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))) + ;; ../../../../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) + rule fun_vextunop___case_1{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))) + ;; ../../../../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) + rule fun_vextunop___case_2{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))) + ;; ../../../../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) + rule fun_vextunop___case_3{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))) + ;; ../../../../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) + rule fun_vextunop___case_4{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))) + ;; ../../../../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) + rule fun_vextunop___case_5{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))) + ;; ../../../../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) + rule fun_vextunop___case_6{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))) + ;; ../../../../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) + rule fun_vextunop___case_7{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))) + ;; ../../../../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) + rule fun_vextunop___case_8{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))) + ;; ../../../../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) + rule fun_vextunop___case_9{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))) + ;; ../../../../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) + rule fun_vextunop___case_10{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))) + ;; ../../../../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) + rule fun_vextunop___case_11{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))) + ;; ../../../../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) + rule fun_vextunop___case_12{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))) + ;; ../../../../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) + rule fun_vextunop___case_13{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))) + ;; ../../../../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) + rule fun_vextunop___case_14{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))) + ;; ../../../../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) + rule fun_vextunop___case_15{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))) @@ -11105,300 +13448,399 @@ 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) + rule fun_vextbinop___case_0{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)) + ;; ../../../../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) + rule fun_vextbinop___case_1{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)) + ;; ../../../../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) + rule fun_vextbinop___case_2{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)) + ;; ../../../../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) + rule fun_vextbinop___case_3{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)) + ;; ../../../../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) + rule fun_vextbinop___case_4{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)) + ;; ../../../../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) + rule fun_vextbinop___case_5{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)) + ;; ../../../../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) + rule fun_vextbinop___case_6{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)) + ;; ../../../../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) + rule fun_vextbinop___case_7{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)) + ;; ../../../../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) + rule fun_vextbinop___case_8{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)) + ;; ../../../../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) + rule fun_vextbinop___case_9{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)) + ;; ../../../../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) + rule fun_vextbinop___case_10{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)) + ;; ../../../../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) + rule fun_vextbinop___case_11{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)) + ;; ../../../../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) + rule fun_vextbinop___case_12{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)) + ;; ../../../../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) + rule fun_vextbinop___case_13{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)) + ;; ../../../../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) + rule fun_vextbinop___case_14{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)) + ;; ../../../../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) + rule fun_vextbinop___case_15{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)) + ;; ../../../../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) + rule fun_vextbinop___case_16{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 $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) + rule fun_vextbinop___case_17{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 $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) + rule fun_vextbinop___case_18{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 $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) + rule fun_vextbinop___case_19{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 $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) + rule fun_vextbinop___case_20{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 $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) + rule fun_vextbinop___case_21{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 $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) + rule fun_vextbinop___case_22{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 $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) + rule fun_vextbinop___case_23{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 $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) + rule fun_vextbinop___case_24{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 $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) + rule fun_vextbinop___case_25{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 $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) + rule fun_vextbinop___case_26{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 $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) + rule fun_vextbinop___case_27{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 $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) + rule fun_vextbinop___case_28{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 $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) + rule fun_vextbinop___case_29{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 $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) + rule fun_vextbinop___case_30{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 $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) + rule fun_vextbinop___case_31{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 $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) + rule fun_vextbinop___case_32{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)) + ;; ../../../../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) + rule fun_vextbinop___case_33{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)) + ;; ../../../../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) + rule fun_vextbinop___case_34{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)) + ;; ../../../../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) + rule fun_vextbinop___case_35{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)) + ;; ../../../../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) + rule fun_vextbinop___case_36{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)) + ;; ../../../../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) + rule fun_vextbinop___case_37{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)) + ;; ../../../../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) + rule fun_vextbinop___case_38{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)) + ;; ../../../../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) + rule fun_vextbinop___case_39{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)) + ;; ../../../../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) + rule fun_vextbinop___case_40{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)) + ;; ../../../../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) + rule fun_vextbinop___case_41{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)) + ;; ../../../../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) + rule fun_vextbinop___case_42{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)) + ;; ../../../../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) + rule fun_vextbinop___case_43{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)) + ;; ../../../../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) + rule fun_vextbinop___case_44{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)) + ;; ../../../../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) + rule fun_vextbinop___case_45{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)) + ;; ../../../../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) + rule fun_vextbinop___case_46{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)) + ;; ../../../../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) + rule fun_vextbinop___case_47{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)) ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11411,11 +13853,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11428,11 +13875,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11445,11 +13897,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11462,11 +13919,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11479,11 +13941,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11496,11 +13963,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11513,11 +13985,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11530,11 +14007,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11547,11 +14029,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11564,11 +14051,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11581,11 +14073,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11598,11 +14095,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11615,11 +14117,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11632,11 +14139,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11649,11 +14161,16 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) + ;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11666,9 +14183,9 @@ def $vextternop__(ishape_1 : ishape, ishape_2 : ishape, vextternop__ : vextterno -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (c <- var_2) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax num = @@ -11896,334 +14413,832 @@ def $fieldval_val(val) : fieldval 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 +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 +relation fun_packfield__before_fun_packfield__case_9: `%%`(storagetype, val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_8{i : uN}: + `%%`(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) + -- wf_fieldval: `%`(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_7{i : uN}: + `%%`(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) + -- wf_fieldval: `%`(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_6{val : val}: + `%%`(I32_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_5{val : val}: + `%%`(I64_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_4{val : val}: + `%%`(F32_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_3{val : val}: + `%%`(F64_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_2{val : val}: + `%%`(V128_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_1{`null?` : null?, heaptype : heaptype, val : val}: + `%%`(REF_storagetype(`null?`, heaptype), val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_0{val : val}: + `%%`(BOT_storagetype, val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_packfield_: `%%%`(storagetype, val, fieldval?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_0{val : val}: + `%%%`(BOT_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_1{`null?` : null?, heaptype : heaptype, val : val}: + `%%%`(REF_storagetype(`null?`, heaptype), val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_2{val : val}: + `%%%`(V128_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_3{val : val}: + `%%%`(F64_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_4{val : val}: + `%%%`(F32_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_5{val : val}: + `%%%`(I64_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_6{val : val}: + `%%%`(I32_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_7{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 + rule fun_packfield__case_8{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))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_9{x0 : storagetype, x1 : val}: + `%%%`(x0, x1, ?()) + -- ~ fun_packfield__before_fun_packfield__case_9: `%%`(x0, x1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_unpackfield__before_fun_unpackfield__case_72: `%%%`(storagetype, sx?, fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_71{sx : sx, i : uN}: + `%%%`(I16_storagetype, ?(sx), PACK_fieldval(I16_packtype, i)) + -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_70{sx : sx, i : uN}: + `%%%`(I8_storagetype, ?(sx), PACK_fieldval(I8_packtype, 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 + rule fun_unpackfield__case_69{numtype : numtype, var_0 : num_}: + `%%%`(I32_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_68{numtype : numtype, var_0 : num_}: + `%%%`(I64_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_67{numtype : numtype, var_0 : num_}: + `%%%`(F32_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_66{numtype : numtype, var_0 : num_}: + `%%%`(F64_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_65{numtype : numtype, var_0 : num_}: + `%%%`(V128_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_64{numtype : numtype, var_0 : num_, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_63{numtype : numtype, var_0 : num_}: + `%%%`(BOT_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_62{vectype : vectype, var_1 : vec_}: + `%%%`(I32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_61{vectype : vectype, var_1 : vec_}: + `%%%`(I64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_60{vectype : vectype, var_1 : vec_}: + `%%%`(F32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_59{vectype : vectype, var_1 : vec_}: + `%%%`(F64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_58{vectype : vectype, var_1 : vec_}: + `%%%`(V128_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_57{vectype : vectype, var_1 : vec_, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_56{vectype : vectype, var_1 : vec_}: + `%%%`(BOT_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_55{u31 : u31}: + `%%%`(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_54{u31 : u31}: + `%%%`(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_53{u31 : u31}: + `%%%`(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_52{u31 : u31}: + `%%%`(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_51{u31 : u31}: + `%%%`(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_50{u31 : u31, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_49{u31 : u31}: + `%%%`(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_48: + `%%%`(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_47: + `%%%`(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_46: + `%%%`(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_45: + `%%%`(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_44: + `%%%`(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_43{`null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_42: + `%%%`(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_41{structaddr : structaddr}: + `%%%`(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_40{structaddr : structaddr}: + `%%%`(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_39{structaddr : structaddr}: + `%%%`(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_38{structaddr : structaddr}: + `%%%`(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_37{structaddr : structaddr}: + `%%%`(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_36{structaddr : structaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_35{structaddr : structaddr}: + `%%%`(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + ;; ../../../../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) + rule fun_unpackfield__case_34{arrayaddr : arrayaddr}: + `%%%`(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) ;; ../../../../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) + rule fun_unpackfield__case_33{arrayaddr : arrayaddr}: + `%%%`(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) ;; ../../../../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 fun_unpackfield__case_32{arrayaddr : arrayaddr}: + `%%%`(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_3: - `%`(`REF.NULL_ADDR`_fieldval) + rule fun_unpackfield__case_31{arrayaddr : arrayaddr}: + `%%%`(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_4{structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_fieldval(structaddr)) + rule fun_unpackfield__case_30{arrayaddr : arrayaddr}: + `%%%`(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_5{arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_fieldval(arrayaddr)) + rule fun_unpackfield__case_29{arrayaddr : arrayaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `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)) + rule fun_unpackfield__case_28{arrayaddr : arrayaddr}: + `%%%`(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_7{exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_fieldval(exnaddr)) + rule fun_unpackfield__case_27{funcaddr : funcaddr}: + `%%%`(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_8{hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_fieldval(hostaddr)) + rule fun_unpackfield__case_26{funcaddr : funcaddr}: + `%%%`(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_9{ref : ref}: - `%`(`REF.EXTERN`_fieldval(ref)) - -- wf_ref: `%`(ref) + rule fun_unpackfield__case_25{funcaddr : funcaddr}: + `%%%`(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) ;; ../../../../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 fun_unpackfield__case_24{funcaddr : funcaddr}: + `%%%`(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax structinst = -{ - TYPE deftype, - FIELDS fieldval* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_23{funcaddr : funcaddr}: + `%%%`(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) -;; ../../../../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} + rule fun_unpackfield__case_22{funcaddr : funcaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax arrayinst = -{ - TYPE deftype, - FIELDS fieldval* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_21{funcaddr : funcaddr}: + `%%%`(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) -;; ../../../../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} + rule fun_unpackfield__case_20{exnaddr : exnaddr}: + `%%%`(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax exninst = -{ - TAG tagaddr, - FIELDS val* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_19{exnaddr : exnaddr}: + `%%%`(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) -;; ../../../../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} + rule fun_unpackfield__case_18{exnaddr : exnaddr}: + `%%%`(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) -;; ../../../../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 + rule fun_unpackfield__case_17{exnaddr : exnaddr}: + `%%%`(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) -;; ../../../../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} + rule fun_unpackfield__case_16{exnaddr : exnaddr}: + `%%%`(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax state = - | `%;%`(store : store, frame : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_15{exnaddr : exnaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) -;; ../../../../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) + rule fun_unpackfield__case_14{exnaddr : exnaddr}: + `%%%`(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax config = - | `%;%`(state : state, `instr*` : instr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_13{hostaddr : hostaddr}: + `%%%`(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) -;; ../../../../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*`} + rule fun_unpackfield__case_12{hostaddr : hostaddr}: + `%%%`(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $Ki : nat ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $Ki = 1024 + rule fun_unpackfield__case_11{hostaddr : hostaddr}: + `%%%`(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) -;; ../../../../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)) + rule fun_unpackfield__case_10{hostaddr : hostaddr}: + `%%%`(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + ;; ../../../../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)) + rule fun_unpackfield__case_9{hostaddr : hostaddr}: + `%%%`(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{val : val}(V128_storagetype, val) = ?($fieldval_val(val)) + rule fun_unpackfield__case_8{hostaddr : hostaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{val : val}(F64_storagetype, val) = ?($fieldval_val(val)) + rule fun_unpackfield__case_7{hostaddr : hostaddr}: + `%%%`(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{val : val}(F32_storagetype, val) = ?($fieldval_val(val)) + rule fun_unpackfield__case_6{ref : ref}: + `%%%`(I32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{val : val}(I64_storagetype, val) = ?($fieldval_val(val)) + rule fun_unpackfield__case_5{ref : ref}: + `%%%`(I64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{val : val}(I32_storagetype, val) = ?($fieldval_val(val)) + rule fun_unpackfield__case_4{ref : ref}: + `%%%`(F32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + ;; ../../../../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))) + rule fun_unpackfield__case_3{ref : ref}: + `%%%`(F64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + ;; ../../../../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 + rule fun_unpackfield__case_2{ref : ref}: + `%%%`(V128_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_1{ref : ref, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_0{ref : ref}: + `%%%`(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $unpackfield_(storagetype : storagetype, sx?, fieldval : fieldval) : val? +relation fun_unpackfield_: `%%%%`(storagetype, sx?, 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)) + rule fun_unpackfield__case_0{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)) + rule fun_unpackfield__case_1{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)) + rule fun_unpackfield__case_2{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)) + rule fun_unpackfield__case_3{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)) + rule fun_unpackfield__case_4{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)) + rule fun_unpackfield__case_5{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)) + rule fun_unpackfield__case_6{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)) + rule fun_unpackfield__case_7{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)) + rule fun_unpackfield__case_8{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)) + rule fun_unpackfield__case_9{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)) + rule fun_unpackfield__case_10{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)) + rule fun_unpackfield__case_11{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)) + rule fun_unpackfield__case_12{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)) + rule fun_unpackfield__case_13{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)) + rule fun_unpackfield__case_14{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)) + rule fun_unpackfield__case_15{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)) + rule fun_unpackfield__case_16{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)) + rule fun_unpackfield__case_17{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)) + rule fun_unpackfield__case_18{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)) + rule fun_unpackfield__case_19{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)) + rule fun_unpackfield__case_20{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)) + rule fun_unpackfield__case_21{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)) + rule fun_unpackfield__case_22{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)) + rule fun_unpackfield__case_23{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)) + rule fun_unpackfield__case_24{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)) + rule fun_unpackfield__case_25{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)) + rule fun_unpackfield__case_26{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)) + rule fun_unpackfield__case_27{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)) + rule fun_unpackfield__case_28{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)) + rule fun_unpackfield__case_29{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)) + rule fun_unpackfield__case_30{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)) + rule fun_unpackfield__case_31{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)) + rule fun_unpackfield__case_32{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)) + rule fun_unpackfield__case_33{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)) + rule fun_unpackfield__case_34{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)) + rule fun_unpackfield__case_35{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)) + rule fun_unpackfield__case_36{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)) + rule fun_unpackfield__case_37{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)) + rule fun_unpackfield__case_38{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)) + rule fun_unpackfield__case_39{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)) + rule fun_unpackfield__case_40{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)) + rule fun_unpackfield__case_41{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) + rule fun_unpackfield__case_42: + `%%%%`(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) + rule fun_unpackfield__case_43{`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) + rule fun_unpackfield__case_44: + `%%%%`(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) + rule fun_unpackfield__case_45: + `%%%%`(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) + rule fun_unpackfield__case_46: + `%%%%`(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) + rule fun_unpackfield__case_47: + `%%%%`(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) + rule fun_unpackfield__case_48: + `%%%%`(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)) + rule fun_unpackfield__case_49{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)) + rule fun_unpackfield__case_50{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)) + rule fun_unpackfield__case_51{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)) + rule fun_unpackfield__case_52{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)) + rule fun_unpackfield__case_53{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)) + rule fun_unpackfield__case_54{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)) + rule fun_unpackfield__case_55{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)) + rule fun_unpackfield__case_56{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)) + rule fun_unpackfield__case_57{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)) + rule fun_unpackfield__case_58{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)) + rule fun_unpackfield__case_59{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)) + rule fun_unpackfield__case_60{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)) + rule fun_unpackfield__case_61{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)) + rule fun_unpackfield__case_62{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)) + rule fun_unpackfield__case_63{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)) + rule fun_unpackfield__case_64{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)) + rule fun_unpackfield__case_65{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)) + rule fun_unpackfield__case_66{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)) + rule fun_unpackfield__case_67{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)) + rule fun_unpackfield__case_68{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)) + rule fun_unpackfield__case_69{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)))) + rule fun_unpackfield__case_70{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)))) + rule fun_unpackfield__case_71{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 + rule fun_unpackfield__case_72{x0 : storagetype, x1 : sx?, x2 : fieldval}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_unpackfield__before_fun_unpackfield__case_72: `%%%`(x0, x1, x2) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -12416,87 +15431,101 @@ def $local(state : state, localidx : localidx) : val? 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 $with_local(state : state, localidx : localidx, val : val) : state +relation fun_with_local: `%%%%`(state, localidx, 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)]) + rule fun_with_local_case_0{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 -def $with_global(state : state, globalidx : globalidx, val : val) : state +relation fun_with_global: `%%%%`(state, globalidx, 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)) + rule fun_with_global_case_0{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 -def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state +relation fun_with_table: `%%%%%`(state, tableidx, nat, 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)) + rule fun_with_table_case_0{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 -def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state +relation fun_with_tableinst: `%%%%`(state, tableidx, 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)) + rule fun_with_tableinst_case_0{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 -def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state +relation fun_with_mem: `%%%%%%`(state, memidx, 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)) + rule fun_with_mem_case_0{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 -def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state +relation fun_with_meminst: `%%%%`(state, memidx, 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)) + rule fun_with_meminst_case_0{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 -def $with_elem(state : state, elemidx : elemidx, ref*) : state +relation fun_with_elem: `%%%%`(state, 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)) + rule fun_with_elem_case_0{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 -def $with_data(state : state, dataidx : dataidx, byte*) : state +relation fun_with_data: `%%%%`(state, 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)) + rule fun_with_data_case_0{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))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state +relation fun_with_struct: `%%%%%`(state, structaddr, nat, 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)) + rule fun_with_struct_case_0{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 +relation fun_with_array: `%%%%%`(state, arrayaddr, nat, 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)) + rule fun_with_array_case_0{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 +relation fun_add_structinst: `%%%`(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)) + rule fun_add_structinst_case_0{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 -def $add_arrayinst(state : state, arrayinst*) : state +relation fun_add_arrayinst: `%%%`(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)) + rule fun_add_arrayinst_case_0{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 -def $add_exninst(state : state, exninst*) : state +relation fun_add_exninst: `%%%`(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)) + rule fun_add_exninst_case_0{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 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, at : addrtype, i : uN, `j?` : u64?, rt : reftype, `r'*` : ref*, i' : uN}(tableinst, n, r) = ?(tableinst') + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, at : addrtype, i : uN, `j?` : u64?, rt : reftype, `r'*` : ref*, i' : uN}: + `%%%`(tableinst, n, r) -- wf_tableinst: `%`(tableinst') -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) @@ -12505,13 +15534,31 @@ def $growtable(tableinst : tableinst, nat : nat, ref : ref) : tableinst? -- if ($proj_uN_0(i').0 = (|r'#5*{r'#5 <- `r'*`}| + n)) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#5).0))?{j#5 <- `j?`} -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) - 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 - def $growmem{meminst : meminst, n : nat, meminst' : meminst, at : addrtype, i : uN, `j?` : u64?, `b*` : byte*, i' : uN}(meminst, n) = ?(meminst') + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, at : addrtype, i : uN, `j?` : u64?, rt : reftype, `r'*` : ref*, i' : uN}: + `%%%%`(tableinst, n, r, ?(tableinst')) + -- wf_tableinst: `%`(tableinst') + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#3?{j#3 <- `j?`}), rt), REFS r'#3*{r'#3 <- `r'*`}}) + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#5*{r'#5 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#5).0))?{j#5 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + + ;; ../../../../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 fun_growmem_before_fun_growmem_case_1: `%%`(meminst, nat) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, at : addrtype, i : uN, `j?` : u64?, `b*` : byte*, i' : uN}: + `%%`(meminst, n) -- wf_meminst: `%`(meminst') -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) @@ -12520,8 +15567,25 @@ def $growmem(meminst : meminst, nat : nat) : meminst? -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#9*{b#9 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#10).0))?{j#10 <- `j?`} -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() - -- otherwise + +;; ../../../../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, at : addrtype, i : uN, `j?` : u64?, `b*` : byte*, i' : uN}: + `%%%`(meminst, n, ?(meminst')) + -- wf_meminst: `%`(meminst') + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#8?{j#8 <- `j?`})), BYTES b#7*{b#7 <- `b*`}}) + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#9?{j#9 <- `j?`})), BYTES b#8*{b#8 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#9*{b#9 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#10).0))?{j#10 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + + ;; ../../../../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.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) @@ -12564,7 +15628,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.STRUCTS_store|) -- if (s.STRUCTS_store[a].TYPE_structinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:45.1-47.30 @@ -12573,7 +15636,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.ARRAYS_store|) -- if (s.ARRAYS_store[a].TYPE_arrayinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:49.1-51.29 @@ -12582,7 +15644,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:53.1-55.24 @@ -12592,7 +15653,6 @@ relation Ref_ok: `%|-%:%`(store, ref, reftype) -- wf_exninst: `%`(exn) -- wf_ref: `%`(`REF.EXN_ADDR`_ref(a)) -- wf_reftype: `%`(REF_reftype(?(), EXN_heaptype)) - -- if (a < |s.EXNS_store|) -- if (s.EXNS_store[a] = exn) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:57.1-58.35 @@ -12684,7 +15744,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) -- wf_store: `%`(s) -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) - -- if (a < |s.TAGS_store|) -- if (s.TAGS_store[a] = taginst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:109.1-111.34 @@ -12692,7 +15751,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) -- wf_store: `%`(s) -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) - -- if (a < |s.GLOBALS_store|) -- if (s.GLOBALS_store[a] = globalinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:113.1-115.28 @@ -12700,7 +15758,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) -- wf_store: `%`(s) -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) - -- if (a < |s.MEMS_store|) -- if (s.MEMS_store[a] = meminst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:117.1-119.32 @@ -12708,7 +15765,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) -- wf_store: `%`(s) -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) - -- if (a < |s.TABLES_store|) -- if (s.TABLES_store[a] = tableinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:121.1-123.30 @@ -12716,7 +15772,6 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) -- wf_store: `%`(s) -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) - -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a] = funcinst) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:125.1-128.37 @@ -12731,29 +15786,39 @@ 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, (iter_val#3 : deftype <: typeuse)*{iter_val#3 <- moduleinst.TYPES_moduleinst}) + 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 fun_inst_reftype: `%%%`(moduleinst, 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}) + 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_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype +relation fun_inst_globaltype: `%%%`(moduleinst, 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}) + 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 -def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype +relation fun_inst_memtype: `%%%`(moduleinst, 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}) + 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_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype +relation fun_inst_tabletype: `%%%`(moduleinst, 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}) + 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.3-execution.instructions.spectec relation `Step_pure_before_br_on_null-addr`: `%`(instr*) @@ -12868,7 +15933,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12878,7 +15942,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12887,7 +15950,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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*`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12896,7 +15958,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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*`})) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12929,7 +15990,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) -- wf_instr: `%`(BR_instr(l)) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12937,17 +15997,15 @@ relation Step_pure: `%~>%`(instr*, instr*) `%~>%`([CONST_instr(I32_numtype, c) BR_IF_instr(l)], []) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_instr: `%`(BR_IF_instr(l)) - -- if ($proj_num__0(c) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) ;; ../../../../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_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])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |l*{l <- `l*`}|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `br_table-ge`{i : num_, `l*` : labelidx*, l' : labelidx}: @@ -12955,7 +16013,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, i)) -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) -- wf_instr: `%`(BR_instr(l')) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13069,7 +16126,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))))) @@ -13186,49 +16242,51 @@ 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)]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) - -- if (|$unop_(nt, unop, c_1)| > 0) - -- if (c <- $unop_(nt, unop, c_1)) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) - -- if ($unop_(nt, unop, c_1) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- if (|$binop_(nt, binop, c_1, c_2)| > 0) - -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(TRAP_instr) - -- if ($binop_(nt, binop, c_1, c_2) = []) + -- if (var_0 = []) + -- 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_}: + rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_, var_0 : u32}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(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)) = var_0) + -- fun_testop_: `%%%%`(nt, testop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: @@ -13237,25 +16295,25 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(RELOP_instr(nt, relop)) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) - -- if ($proj_num__0(c) =/= ?()) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) ;; ../../../../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)]) -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(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) + -- 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]) -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) - -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- if (var_0 = []) + -- 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_}: @@ -13263,7 +16321,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13273,7 +16330,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_2)) -- wf_instr: `%`(VVBINOP_instr(V128_vectype, vvbinop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13284,77 +16340,79 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_3)) -- wf_instr: `%`(VVTERNOP_instr(V128_vectype, vvternop)) -- wf_instr: `%`(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)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vvtestop{c_1 : vec_, c : num_}: + rule vvtestop{c_1 : vec_, c : num_, var_0 : u32}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(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)) = var_0) + -- fun_inez_: `%%%`($vsize(V128_vectype), c_1, var_0) ;; ../../../../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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vunop_(sh, vunop, c_1)| > 0) - -- if (c <- $vunop_(sh, vunop, c_1)) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) - -- if ($vunop_(sh, vunop, c_1) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- if (|$vbinop_(sh, vbinop, c_1, c_2)| > 0) - -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- if (c <- var_0) + -- 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]) -- 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) - -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- 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) + -- 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]) -- 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) - -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- if (var_0 = []) + -- 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*` : uN*}: `%~>%`([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)]) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), i))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) @@ -13362,64 +16420,67 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) -- 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 = $prod($proj_uN_0(var_0).0*{var_0 <- `var_0*`})) + -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_0))*{var_0 <- `var_0*`, i <- `i*`} ;; ../../../../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)]) -- 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)) - -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- if (c = var_0) + -- 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)]) -- 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)) - -- if ($proj_num__0(i) =/= ?()) - -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- if (c = var_0) + -- 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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(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) + -- 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)]) -- 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)) - -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- if (c = var_0) + -- 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)]) -- 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)) - -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- if (c = var_0) + -- 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_}: + rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_, var_0 : lane_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- 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))) - -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), var_0^M{})) + -- fun_lpacknum_: `%%%`(Lnn, c_1, var_0) ;; ../../../../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_}: @@ -13429,7 +16490,6 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- 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))) - -- 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]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13439,98 +16499,106 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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($lanetype_packtype(pt), `%`_dim(M))) - -- 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])))) ;; ../../../../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_}: + rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_, var_0 : lane_}: `%~>%`([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)]) -- 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))) - -- 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)])) + -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = var_0])) + -- fun_lpacknum_: `%%%`(Lnn, c_2, var_0) ;; ../../../../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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- if (var_0 = 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)]) -- 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)) - -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- if (var_0 = 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)]) -- 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)) - -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- if (var_0 = 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)]) -- 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)) - -- if (c = $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) + -- if (c = var_0) + -- 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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- if (c = var_0) + -- 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*`})) + 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*`}))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), [], `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#5*{t_1#5 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `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?`}))) + rule fun_blocktype__case_1{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 `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, rt : reftype}: + rule `br_on_cast-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_reftype: `%`(rt) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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, rt : reftype}: + rule `br_on_cast_fail-succeed_0`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_reftype: `%`(rt) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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) @@ -13554,8 +16622,6 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- 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)) - -- 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) @@ -13565,8 +16631,6 @@ relation `Step_read_before_throw_ref-handler-next`: `%`(config) -- (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)) - -- 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) @@ -13577,7 +16641,6 @@ relation `Step_read_before_table.fill-zero`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13594,7 +16657,6 @@ relation `Step_read_before_table.fill-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13604,8 +16666,6 @@ relation `Step_read_before_table.copy-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13622,8 +16682,6 @@ relation `Step_read_before_table.copy-le`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13636,9 +16694,7 @@ relation `Step_read_before_table.copy-gt`: `%`(config) -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) -- wf_instr: `%`(`TABLE.GET`_instr(y)) -- wf_instr: `%`(`TABLE.SET`_instr(x)) - -- if ($proj_num__0(i_1) =/= ?()) -- 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))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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)) @@ -13657,8 +16713,6 @@ relation `Step_read_before_table.copy-gt`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13668,8 +16722,6 @@ relation `Step_read_before_table.init-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13686,8 +16738,6 @@ relation `Step_read_before_table.init-succ`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13697,7 +16747,6 @@ relation `Step_read_before_memory.fill-zero`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13714,7 +16763,6 @@ relation `Step_read_before_memory.fill-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13724,8 +16772,6 @@ relation `Step_read_before_memory.copy-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13742,28 +16788,25 @@ relation `Step_read_before_memory.copy-le`: `%`(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_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) - -- 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|)) ;; ../../../../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}: + 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, var_0 : memarg}: `%`(`%;%`_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_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)) - -- if ($proj_num__0(i_1) =/= ?()) + -- wf_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) -- 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))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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)) -- ~ `Step_read_before_memory.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))) `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) + -- fun_memarg0: `%`(var_0) ;; ../../../../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}: @@ -13777,8 +16820,6 @@ relation `Step_read_before_memory.copy-gt`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13788,8 +16829,6 @@ relation `Step_read_before_memory.init-zero`: `%`(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_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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13806,32 +16845,32 @@ relation `Step_read_before_memory.init-succ`: `%`(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_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) - -- 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|)) ;; ../../../../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, rt' : reftype}: + rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_reftype: `%`(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)))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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, rt' : reftype}: + rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_reftype: `%`(rt') -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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) @@ -13840,8 +16879,6 @@ relation `Step_read_before_array.fill-zero`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13858,8 +16895,6 @@ relation `Step_read_before_array.fill-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13869,8 +16904,6 @@ relation `Step_read_before_array.copy-zero`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13878,8 +16911,6 @@ relation `Step_read_before_array.copy-zero`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13896,8 +16927,6 @@ relation `Step_read_before_array.copy-le`: `%`(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_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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13905,14 +16934,12 @@ relation `Step_read_before_array.copy-le`: `%`(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_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) - -- 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|) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: + rule `array.copy-le_0`{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, var_0 : sx??}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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_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)) @@ -13921,17 +16948,15 @@ 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)) - -- if ($proj_num__0(i_1) =/= ?()) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) - -- if ($proj_num__0(i_2) =/= ?()) -- 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))) -- ~ `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)))) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx}: @@ -13945,8 +16970,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)])) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13954,8 +16977,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)])) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13965,7 +16986,6 @@ relation `Step_read_before_array.init_elem-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_ELEM`_instr(x, 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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13973,8 +16993,6 @@ relation `Step_read_before_array.init_elem-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_ELEM`_instr(x, 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13991,7 +17009,6 @@ relation `Step_read_before_array.init_elem-succ`: `%`(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_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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -13999,30 +17016,25 @@ relation `Step_read_before_array.init_elem-succ`: `%`(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_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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: + rule `array.init_data-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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_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))) -- 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|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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)])) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14035,52 +17047,52 @@ relation `Step_read_before_array.init_data-num`: `%`(config) -- if (n = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: + rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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_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))) -- 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|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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)])) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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*`})]) -- 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 ($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*`}))) + -- 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*`})]) -- 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 ($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*`}))) + -- 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, rt : reftype}: + rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : 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)]) -- wf_reftype: `%`(rt) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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}: @@ -14089,13 +17101,14 @@ relation Step_read: `%~>%`(config, instr*) -- ~ `Step_read_before_br_on_cast-fail`: `%`(`%;%`_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, rt : reftype}: + rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : reftype, var_0 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) -- wf_reftype: `%`(rt) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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}: @@ -14107,11 +17120,9 @@ 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)|) -- 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))) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14121,28 +17132,25 @@ relation Step_read: `%~>%`(config, instr*) -- 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*}: + 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*, `var_0*` : val??*}: `%~>%`(`%;%`_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*`})])]) -- 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*`})) - -- (if ($default_(t) =/= ?()))*{t <- `t*`} - -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) - -- if (a < |$funcinst(z)|) + -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !(var_0)*{var_0 <- `var_0*`}, MODULE fi.MODULE_funcinst}) -- 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}) + -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !(var_0)*{var_0 <- `var_0*`}, MODULE fi.MODULE_funcinst}) + -- (fun_default_: `%%`(t, var_0))*{var_0 <- `var_0*`, t <- `t*`} ;; ../../../../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)|) -- 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))) - -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14170,7 +17178,6 @@ relation Step_read: `%~>%`(config, 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 (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*`}))) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14214,8 +17221,6 @@ relation Step_read: `%~>%`(config, instr*) -- (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)) - -- 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) @@ -14226,8 +17231,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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)) - -- 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) @@ -14252,12 +17255,13 @@ relation Step_read: `%~>%`(config, instr*) -- ~ `Step_read_before_throw_ref-handler-next`: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [catch] ++ 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*`})])]) -- 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 ($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*`}))) + -- fun_blocktype_: `%%%`(z, bt, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `local.get`{z : state, x : idx, val : val}: @@ -14278,15 +17282,13 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) ;; ../../../../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($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($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `table.size`{z : state, x : idx, at : addrtype, n : n, lim : limits, rt : reftype}: @@ -14302,7 +17304,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14315,7 +17316,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) =/= ?()) -- 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)) @@ -14329,8 +17329,6 @@ relation Step_read: `%~>%`(config, 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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14343,8 +17341,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) =/= ?()) -- 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)) @@ -14360,8 +17356,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) =/= ?()) -- 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))))) -- 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))))) @@ -14378,8 +17372,6 @@ relation Step_read: `%~>%`(config, 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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14392,9 +17384,6 @@ 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) =/= ?()) -- 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)) @@ -14409,7 +17398,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14417,7 +17405,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)]), [CONST_instr(nt, c)]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14425,7 +17412,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14433,7 +17419,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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)))]) -- 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)))) - -- 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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14441,7 +17426,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14449,7 +17433,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(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)]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14457,7 +17440,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), K, sx)), x, ao)]), [TRAP_instr]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14467,7 +17449,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(K))) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(K))), mk_lane__2_lane_(Jnn, $extend__(M, $jsizenn(Jnn), sx, j))))^K{j <- `j*`} - -- (if ($proj_num__0(i) =/= ?()))^(k rat) / (8 : nat <:> rat)) : rat <:> nat)) : (((M : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]))^(k%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14486,7 +17466,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- 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))) - -- 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))) @@ -14497,7 +17476,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [TRAP_instr]) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14506,7 +17484,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_uN: `%%`(N, 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)) - -- 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)) @@ -14515,7 +17492,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14525,7 +17501,6 @@ relation Step_read: `%~>%`(config, instr*) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- 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))) - -- 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))) @@ -14545,7 +17520,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14556,24 +17530,22 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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) =/= ?()) + rule `memory.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) 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)]) -- 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: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, var_0)) -- 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)) -- ~ `Step_read_before_memory.fill-succ`: `%`(`%;%`_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)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14584,45 +17556,41 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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) =/= ?()) + 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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0) 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)]) -- 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: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) -- 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)) -- ~ `Step_read_before_memory.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))) `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) + -- fun_memarg0: `%`(var_0) ;; ../../../../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) =/= ?()) + 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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0) 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)]) -- 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: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) -- 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)) -- ~ `Step_read_before_memory.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))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../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]) -- 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) - -- 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|)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14633,20 +17601,18 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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) =/= ?()) + rule `memory.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) 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)]) -- 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)))) - -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, $memarg0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, var_0)) -- 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)) -- ~ `Step_read_before_memory.init-succ`: `%`(`%;%`_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)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.null`{z : state, ht : heaptype}: @@ -14657,19 +17623,19 @@ 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, rt' : reftype}: + rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype, 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)))]) -- wf_reftype: `%`(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)))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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}: @@ -14679,13 +17645,14 @@ relation Step_read: `%~>%`(config, instr*) -- ~ `Step_read_before_ref.test-false`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype}: + rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [$instr_ref(ref)]) -- wf_reftype: `%`(rt') -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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}: @@ -14695,16 +17662,16 @@ relation Step_read: `%~>%`(config, instr*) -- ~ `Step_read_before_ref.cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*}: + rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*, `var_1*` : valtype*, `var_0*` : val??*}: `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(val)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) -- (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*`}))) -- 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*`} + -- (if (!(var_0) = ?(val)))*{var_0 <- `var_0*`, val <- `val*`} + -- (fun_unpack: `%%`(zt, var_1))*{var_1 <- `var_1*`, zt <- `zt*`} + -- (fun_default_: `%%`(var_1, var_0))*{var_1 <- `var_1*`, var_0 <- `var_0*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.get-null`{z : state, `sx?` : sx?, x : idx, i : fieldidx}: @@ -14713,33 +17680,30 @@ relation Step_read: `%~>%`(config, instr*) -- 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)]), [$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)|) + rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*, var_0 : val?}: + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [$instr_val(!(var_0))]) -- 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*`}))) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- fun_unpackfield_: `%%%%`(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0], var_0) ;; ../../../../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}: + rule `array.new_default`{z : state, n : n, x : idx, val : val, `mut?` : mut?, zt : storagetype, var_1 : valtype, var_0 : val??}: `%~>%`(`%;%`_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))]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($default_($unpack(zt)) =/= ?()) - -- if (!($default_($unpack(zt))) = ?(val)) + -- if (!(var_0) = ?(val)) + -- fun_unpack: `%%`(zt, var_1) + -- fun_default_: `%%`(var_1, var_0) ;; ../../../../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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14748,32 +17712,31 @@ relation Step_read: `%~>%`(config, instr*) -- (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))) - -- if ($proj_num__0(i) =/= ?()) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : 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}: + rule `array.new_data-oob`{z : state, i : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: `%~>%`(`%;%`_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]) -- 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))) -- 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|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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{} + rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?, var_3 : nat?, `var_2*` : lit_*, var_1 : consttype?, `var_0*` : 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)]), var_0^n{var_0 <- `var_0*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- (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))) -- 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)]) + -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !(var_3)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- fun_zsize: `%%`(zt, var_3) + -- (fun_cunpacknum_: `%%%`(zt, c, var_2))^n{var_2 <- `var_2*`, c <- `c*`} + -- fun_cunpack: `%%`(zt, var_1) + -- (fun_const: `%%%`(!(var_1), var_2, var_0))^n{var_2 <- `var_2*`, var_0 <- `var_0*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -14786,20 +17749,15 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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) =/= ?()) + rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?, var_0 : val?}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [$instr_val(!(var_0))]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- fun_unpackfield_: `%%%%`(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.len-null`{z : state}: @@ -14810,7 +17768,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|)))) @@ -14825,8 +17782,6 @@ relation Step_read: `%~>%`(config, 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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14839,7 +17794,6 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../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) =/= ?()) -- 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)) @@ -14866,8 +17820,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14875,8 +17827,6 @@ relation Step_read: `%~>%`(config, instr*) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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]) -- 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) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14887,10 +17837,8 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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}: + 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, var_0 : sx??}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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) =/= ?()) -- 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)) @@ -14905,14 +17853,12 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 ($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_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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}: + 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, var_0 : sx??}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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) =/= ?()) -- 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))))) @@ -14927,8 +17873,8 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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?{sx <- `sx?`} = !(var_0)) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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}: @@ -14941,8 +17887,6 @@ 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_ELEM`_instr(x, y)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14950,7 +17894,6 @@ 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_ELEM`_instr(x, y)]), [TRAP_instr]) -- 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) - -- if ($proj_num__0(j) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14963,8 +17906,6 @@ 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) $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) =/= ?()) -- 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)) @@ -14975,7 +17916,6 @@ relation Step_read: `%~>%`(config, instr*) -- 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)) -- ~ `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 ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -14989,20 +17929,17 @@ 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]) -- 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) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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}: + rule `array.init_data-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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.ARRAY_ADDR`_instr(a) 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))) -- 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|) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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}: @@ -15012,25 +17949,25 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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) =/= ?()) + 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?, var_3 : nat?, var_2 : lit_, var_1 : consttype?, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 + (((!(var_3) : 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)]) -- 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_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(($proj_uN_0(!($proj_num__0(j))).0 + (((!(var_3) : 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))) -- ~ `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 ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- fun_zsize: `%%`(zt, var_3) + -- fun_cunpacknum_: `%%%`(zt, c, var_2) + -- fun_cunpack: `%%`(zt, var_1) + -- fun_const: `%%%`(!(var_1), var_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rec { @@ -15089,167 +18026,168 @@ relation Step: `%~>%`(config, config) -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr*{instr <- `instr*`}), `%;%`_config(`%;%`_state(s', f''), instr'*{instr' <- `instr'*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:231.1-235.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])) + rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_1 : deftype?, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- 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_config: `%`(`%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) - -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- if ($as_deftype($tag(z, x).TYPE_taginst) =/= ?()) - -- Expand: `%~~%`(!($as_deftype($tag(z, x).TYPE_taginst)), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) + -- Expand: `%~~%`(!(var_1), `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*`}}) + -- fun_as_deftype: `%%`($tag(z, x).TYPE_taginst, var_1) + -- fun_add_exninst: `%%%`(z, [exn], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:309.1-310.56 - rule `local.set`{z : state, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)]), `%;%`_config($with_local(z, x, val), [])) + rule `local.set`{z : state, val : val, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_local(z, x, val), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_local: `%%%%`(z, x, val, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:322.1-323.58 - rule `global.set`{z : state, val : val, x : idx}: - `%~>%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)]), `%;%`_config($with_global(z, x, val), [])) + rule `global.set`{z : state, val : val, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_global(z, x, val), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_global: `%%%%`(z, x, val, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.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])) -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) - -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:340.1-342.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) =/= ?()) + rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config(var_0, [])) -- 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), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- fun_with_table: `%%%%%`(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:351.1-354.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|)))])) + rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst, var_1 : tableinst?, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) -- 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|)))])) - -- if ($growtable($table(z, x), n, ref) =/= ?()) - -- if (ti = !($growtable($table(z, x), n, ref))) + -- wf_config: `%`(`%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- if (ti = !(var_1)) + -- fun_growtable: `%%%%`($table(z, x), n, ref, var_1) + -- fun_with_tableinst: `%%%%`(z, x, ti, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:356.1-357.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:417.1-418.51 - rule `elem.drop`{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config($with_elem(z, x, []), [])) + rule `elem.drop`{z : state, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_elem(z, x, []), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_elem: `%%%%`(z, x, [], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:501.1-504.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])) -- 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) =/= ?()) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:506.1-510.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) =/= ?()) + rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(var_0, [])) -- 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*`}), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- fun_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*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:512.1-515.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])) -- 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])) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:517.1-521.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) =/= ?()) + rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_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(var_0, [])) -- 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(c) =/= ?()) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))) + -- fun_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*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:523.1-526.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])) -- 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) =/= ?()) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:528.1-531.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) =/= ?()) + rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(var_0, [])) -- 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*`}), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- fun_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*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:534.1-537.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])) -- 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])) - -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:539.1-544.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) =/= ?()) + 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, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(var_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_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_config: `%`(`%;%`_config(var_0, [])) -- 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)) -- 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($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) + -- fun_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*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:553.1-556.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))))])) + rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst, var_1 : meminst?, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) -- 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))))])) - -- if ($growmem($mem(z, x), n) =/= ?()) - -- if (mi = !($growmem($mem(z, x), n))) + -- wf_config: `%`(`%;%`_config(var_0, [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_1)) + -- fun_growmem: `%%%`($mem(z, x), n, var_1) + -- fun_with_meminst: `%%%%`(z, x, mi, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:558.1-559.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:619.1-620.51 - rule `data.drop`{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config($with_data(z, x, []), [])) + rule `data.drop`{z : state, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [`DATA.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_data(z, x, []), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_data: `%%%%`(z, x, [], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:700.1-704.65 - rule `struct.new`{z : state, n : n, `val*` : val*, x : idx, si : structinst, a : addr, `mut?*` : mut?*, `zt*` : storagetype*}: - `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config($add_structinst(z, [si]), [`REF.STRUCT_ADDR`_instr(a)])) + rule `struct.new`{z : state, n : n, `val*` : val*, x : idx, si : structinst, a : addr, `mut?*` : mut?*, `zt*` : storagetype*, `var_1*` : fieldval?*, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config(var_0, [`REF.STRUCT_ADDR`_instr(a)])) -- 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_config: `%`(`%;%`_config(var_0, [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} - -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}}) -- 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*`}}) + -- if (si = {TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}}) + -- (fun_packfield_: `%%%`(zt, val, var_1))^n{var_1 <- `var_1*`, val <- `val*`, zt <- `zt*`} + -- fun_add_structinst: `%%%`(z, [si], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:721.1-722.55 rule `struct.set-null`{z : state, val : val, x : idx, i : fieldidx}: @@ -15258,25 +18196,26 @@ relation Step: `%~>%`(config, config) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:724.1-727.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*`}|) + rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*, var_1 : fieldval?, var_0 : state}: + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config(var_0, [])) -- 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))), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- fun_packfield_: `%%%`(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val, var_1) + -- fun_with_struct: `%%%%%`(z, a, $proj_uN_0(i).0, !(var_1), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:740.1-745.65 - 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)])) + rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype, `var_1*` : fieldval?*, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config(var_0, [`REF.ARRAY_ADDR`_instr(a)])) -- 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_config: `%`(`%;%`_config(var_0, [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} - -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) + -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}}) -- 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*`}})) + -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}})) + -- (fun_packfield_: `%%%`(zt, val, var_1))^n{var_1 <- `var_1*`, val <- `val*`} + -- fun_add_arrayinst: `%%%`(z, [ai], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:785.1-786.66 rule `array.set-null`{z : state, i : num_, val : val, x : idx}: @@ -15289,19 +18228,17 @@ relation Step: `%~>%`(config, config) `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(z, [TRAP_instr])) -- 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])) - -- if ($proj_num__0(i) =/= ?()) - -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:792.1-795.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) =/= ?()) + rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?, var_1 : fieldval?, var_0 : state}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(var_0, [])) -- 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))), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- fun_packfield_: `%%%`(zt, val, var_1) + -- fun_with_array: `%%%%%`(z, a, $proj_uN_0(!($proj_num__0(i))).0, !(var_1), var_0) } ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -15336,23 +18273,30 @@ 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*, `deftype*` : deftype*, rectype : rectype, x : uN}(type'#1*{type'#1 <- `type'*`} ++ [type]) = deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`} +;; ../../../../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*, `deftype*` : deftype*, rectype : rectype, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: + `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) + -- 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) -- wf_uN: `%%`(32, x) - -- if (deftype'#1*{deftype'#1 <- `deftype'*`} = $alloctypes(type'#2*{type'#2 <- `type'*`})) + -- if (deftype'#1*{deftype'#1 <- `deftype'*`} = var_0) -- if (type = TYPE_type(rectype)) - -- 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'*`}|) } ;; ../../../../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|)) -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) -- if (taginst = {TYPE tagtype}) @@ -15360,22 +18304,28 @@ def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) ;; ../../../../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_2 : store, ja : nat, `ja'*` : tagaddr*, s_1 : store}(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}) = (s_2, [ja] ++ ja'*{ja' <- `ja'*`}) +;; ../../../../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*, s_2 : store, ja : nat, `ja'*` : tagaddr*, s_1 : store, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: + `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) + -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) + -- fun_alloctag: `%%%`(s, tagtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ja) = $alloctag(s, tagtype)) - -- if ((s_2, ja'#1*{ja'#1 <- `ja'*`}) = $alloctags(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`})) + -- if ((s_1, ja) = var_0) + -- if ((s_2, ja'#1*{ja'#1 <- `ja'*`}) = 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|)) -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) -- if (globalinst = {TYPE globaltype, VALUE val}) @@ -15383,22 +18333,28 @@ def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, gl ;; ../../../../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_2 : store, ga : nat, `ga'*` : globaladdr*, s_1 : store}(s, [globaltype] ++ globaltype'#1*{globaltype'#1 <- `globaltype'*`}, [val] ++ val'#1*{val'#1 <- `val'*`}) = (s_2, [ga] ++ ga'*{ga' <- `ga'*`}) +;; ../../../../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*, s_2 : store, ga : nat, `ga'*` : globaladdr*, s_1 : store, 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'*`})) + -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ga) = $allocglobal(s, globaltype, val)) - -- if ((s_2, ga'#1*{ga'#1 <- `ga'*`}) = $allocglobals(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`})) + -- if ((s_1, ga) = var_0) + -- if ((s_2, ga'#1*{ga'#1 <- `ga'*`}) = var_1) } ;; ../../../../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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#12?{j#12 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#13?{j#13 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) @@ -15406,22 +18362,28 @@ def $allocmem(store : store, memtype : memtype) : (store, memaddr) ;; ../../../../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_2 : store, ma : nat, `ma'*` : memaddr*, s_1 : store}(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}) = (s_2, [ma] ++ ma'*{ma' <- `ma'*`}) +;; ../../../../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*, s_2 : store, ma : nat, `ma'*` : memaddr*, s_1 : store, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: + `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) + -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) + -- fun_allocmem: `%%%`(s, memtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ma) = $allocmem(s, memtype)) - -- if ((s_2, ma'#1*{ma'#1 <- `ma'*`}) = $allocmems(s_1, memtype'#2*{memtype'#2 <- `memtype'*`})) + -- if ((s_1, ma) = var_0) + -- if ((s_2, ma'#1*{ma'#1 <- `ma'*`}) = 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 - 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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#15?{j#15 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#16?{j#16 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) @@ -15429,22 +18391,28 @@ def $alloctable(store : store, tabletype : tabletype, ref : ref) : (store, table ;; ../../../../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_2 : store, ta : nat, `ta'*` : tableaddr*, s_1 : store}(s, [tabletype] ++ tabletype'#1*{tabletype'#1 <- `tabletype'*`}, [ref] ++ ref'#1*{ref'#1 <- `ref'*`}) = (s_2, [ta] ++ ta'*{ta' <- `ta'*`}) +;; ../../../../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*, s_2 : store, ta : nat, `ta'*` : tableaddr*, s_1 : store, 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'*`})) + -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) + -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ta) = $alloctable(s, tabletype, ref)) - -- if ((s_2, ta'#1*{ta'#1 <- `ta'*`}) = $alloctables(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`})) + -- if ((s_1, ta) = var_0) + -- if ((s_2, ta'#1*{ta'#1 <- `ta'*`}) = var_1) } ;; ../../../../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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) @@ -15452,22 +18420,28 @@ def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst ;; ../../../../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_2 : store, fa : nat, `fa'*` : funcaddr*, s_1 : store}(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'*`}) +;; ../../../../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*, s_2 : store, fa : nat, `fa'*` : funcaddr*, s_1 : store, 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'*`})) + -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, fa) = $allocfunc(s, dt, funccode, moduleinst)) - -- if ((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'*`})) + -- if ((s_1, fa) = var_0) + -- if ((s_2, fa'#1*{fa'#1 <- `fa'*`}) = var_1) } ;; ../../../../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 - 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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte#3*{byte#3 <- `byte*`}}) -- if (datainst = {BYTES byte#4*{byte#4 <- `byte*`}}) @@ -15475,22 +18449,28 @@ def $allocdata(store : store, datatype : datatype, byte*) : (store, dataaddr) ;; ../../../../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_2 : store, da : nat, `da'*` : dataaddr*, s_1 : store}(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'*`}) +;; ../../../../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**, s_2 : store, da : nat, `da'*` : dataaddr*, s_1 : store, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: + `%%%%`(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'*`})) + -- 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#11*{b#11 <- `b*`}, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, da) = $allocdata(s, ok, b#11*{b#11 <- `b*`})) - -- if ((s_2, da'#1*{da'#1 <- `da'*`}) = $allocdatas(s_1, ok'#2*{ok'#2 <- `ok'*`}, b'#2*{b'#2 <- `b'*#2`}*{`b'*#2` <- `b'**`})) + -- if ((s_1, da) = var_0) + -- if ((s_2, da'#1*{da'#1 <- `da'*`}) = var_1) } ;; ../../../../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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE elemtype, REFS ref#2*{ref#2 <- `ref*`}}) -- if (eleminst = {TYPE elemtype, REFS ref#3*{ref#3 <- `ref*`}}) @@ -15498,45 +18478,76 @@ def $allocelem(store : store, elemtype : elemtype, ref*) : (store, elemaddr) ;; ../../../../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_2 : store, ea : nat, `ea'*` : elemaddr*, s_1 : store}(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'*`}) +;; ../../../../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**, s_2 : store, ea : nat, `ea'*` : elemaddr*, s_1 : store, 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'*`})) + -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ea) = $allocelem(s, rt, ref#5*{ref#5 <- `ref*`})) - -- if ((s_2, ea'#1*{ea'#1 <- `ea'*`}) = $allocelems(s_1, rt'#2*{rt'#2 <- `rt'*`}, ref'#4*{ref'#4 <- `ref'*#2`}*{`ref'*#2` <- `ref'**`})) + -- if ((s_1, ea) = var_0) + -- if ((s_2, ea'#1*{ea'#1 <- `ea'*`}) = var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocexport(moduleinst : moduleinst, export : export) : exportinst +relation fun_allocexport: `%%%`(moduleinst, 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])} + rule fun_allocexport_case_0{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])} + rule fun_allocexport_case_1{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])} + rule fun_allocexport_case_2{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])} + rule fun_allocexport_case_3{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])} + rule fun_allocexport_case_4{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 -def $allocexports(moduleinst : moduleinst, export*) : exportinst* +relation fun_allocexports: `%%%`(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*`} + rule fun_allocexports_case_0{moduleinst : moduleinst, `export*` : export*, `var_0*` : exportinst*}: + `%%%`(moduleinst, export#4*{export#4 <- `export*`}, var_0*{var_0 <- `var_0*`}) + -- (fun_allocexport: `%%%`(moduleinst, export, var_0))*{var_0 <- `var_0*`, export <- `export*`} ;; ../../../../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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `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) + 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_13 : exportinst*, var_12 : (store, funcaddr*), `var_11*` : elemtype*, var_10 : (store, elemaddr*), var_9 : (store, dataaddr*), `var_8*` : tabletype*, var_7 : (store, tableaddr*), `var_6*` : memtype*, var_5 : (store, memaddr*), `var_4*` : globaltype*, var_3 : (store, globaladdr*), `var_2*` : tagtype*, var_1 : (store, tagaddr*), var_0 : deftype*}: + `%%%%%%%`(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)) + -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_13) + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_12) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_11))*{var_11 <- `var_11*`, elemtype#3 <- `elemtype*`} + -- fun_allocelems: `%%%%`(s_5, var_11*{var_11 <- `var_11*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_10) + -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_9) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_8))*{var_8 <- `var_8*`, tabletype#160 <- `tabletype*`} + -- fun_alloctables: `%%%%`(s_3, var_8*{var_8 <- `var_8*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_7) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_6))*{var_6 <- `var_6*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_6*{var_6 <- `var_6*`}, var_5) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_4))*{var_4 <- `var_4*`, globaltype#126 <- `globaltype*`} + -- fun_allocglobals: `%%%%`(s_1, var_4*{var_4 <- `var_4*`}, val_G#2*{val_G#2 <- `val_G*`}, var_3) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_2))*{var_2 <- `var_2*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_2*{var_2 <- `var_2*`}, var_1) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `type*`}, var_0) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(moduleinst) -- wf_store: `%`(s_1) @@ -15568,38 +18579,46 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`})) -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = $tablesxa(externaddr#5*{externaddr#5 <- `externaddr*`})) -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = $funcsxa(externaddr#6*{externaddr#6 <- `externaddr*`})) - -- if (dt#9*{dt#9 <- `dt*`} = $alloctypes(type#4*{type#4 <- `type*`})) + -- if (dt#9*{dt#9 <- `dt*`} = var_0) -- if (fa#3*{fa#3 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#6*{func#6 <- `func*`}|){}) - -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = $alloctags(s, $subst_all_tagtype(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`})*{tagtype#82 <- `tagtype*`})) - -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = $allocglobals(s_1, $subst_all_globaltype(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`})*{globaltype#126 <- `globaltype*`}, val_G#2*{val_G#2 <- `val_G*`})) - -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = $allocmems(s_2, $subst_all_memtype(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`})*{memtype#126 <- `memtype*`})) - -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = $alloctables(s_3, $subst_all_tabletype(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`})*{tabletype#160 <- `tabletype*`}, ref_T#2*{ref_T#2 <- `ref_T*`})) - -- if ((s_5, da#2*{da#2 <- `da*`}) = $allocdatas(s_4, OK_datatype^|data#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`})) - -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = $allocelems(s_5, $subst_all_reftype(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`})*{elemtype#3 <- `elemtype*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`})) - -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = $allocfuncs(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{})) - -- if (xi#2*{xi#2 <- `xi*`} = $allocexports({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 []}, export#7*{export#7 <- `export*`})) + -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_1) + -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_3) + -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_5) + -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_7) + -- if ((s_5, da#2*{da#2 <- `da*`}) = var_9) + -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_10) + -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_12) + -- if (xi#2*{xi#2 <- `xi*`} = var_13) -- if (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 -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#12^n{b#12 <- `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#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)] + rule fun_rundata__case_1{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)) ;; ../../../../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^n{e#1 <- `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#2^n{e#2 <- `e*`}, DECLARE_elemmode)) = [`ELEM.DROP`_instr(x)] + rule fun_runelem__case_1{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)) + ;; ../../../../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)] + rule fun_runelem__case_2{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)) @@ -15608,46 +18627,60 @@ def $runelem_(elemidx : elemidx, elem : elem) : instr* ;; ../../../../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*, z'' : state, ref : ref, `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*, z'' : state, ref : ref, `ref'*` : ref*, z' : state, var_0 : (state, ref*)}: + `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) -- wf_state: `%`(z'') -- wf_ref: `%`(ref) -- (wf_ref: `%`(ref'#5))*{ref'#5 <- `ref'*`} -- wf_state: `%`(z') -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) - -- if ((z'', ref'#6*{ref'#6 <- `ref'*`}) = $evalexprs(z', expr'#2*{expr'#2 <- `expr'*`})) + -- if ((z'', ref'#6*{ref'#6 <- `ref'*`}) = 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'' : state, `ref*` : ref*, `ref'**` : ref**, z' : state}(z, [expr#365*{expr#365 <- `expr*`}] ++ expr'#3*{expr'#3 <- `expr'*#1`}*{`expr'*#1` <- `expr'**`}) = (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) +;; ../../../../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**, z'' : state, `ref*` : ref*, `ref'**` : ref**, z' : state, 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'**`})) + -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) + -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) -- wf_state: `%`(z'') -- (wf_ref: `%`(ref#6))*{ref#6 <- `ref*`} -- (wf_ref: `%`(ref'#7))*{ref'#7 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`} -- wf_state: `%`(z') - -- if ((z', ref#7*{ref#7 <- `ref*`}) = $evalexprs(z, expr#366*{expr#366 <- `expr*`})) - -- if ((z'', ref'#8*{ref'#8 <- `ref'*#4`}*{`ref'*#4` <- `ref'**`}) = $evalexprss(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`})) + -- if ((z', ref#7*{ref#7 <- `ref*`}) = var_0) + -- if ((z'', ref'#8*{ref'#8 <- `ref'*#4`}*{`ref'*#4` <- `ref'**`}) = 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*, z'' : state, val : val, `val'*` : val*, z' : state, s : store, f : frame, s' : store, a : nat}(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*, z'' : state, val : val, `val'*` : val*, z' : state, s : store, f : frame, s' : store, a : nat, 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'*`})) + -- 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) -- wf_state: `%`(z'') -- wf_val: `%`(val) -- (wf_val: `%`(val'#3))*{val'#3 <- `val'*`} @@ -15656,14 +18689,23 @@ def $evalglobals(state : state, globaltype*, expr*) : (state, val*) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [val]) -- if (z' = `%;%`_state(s, f)) - -- if ((s', a) = $allocglobal(s, gt, val)) - -- if ((z'', val'#4*{val'#4 <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'#2*{gt'#2 <- `gt'*`}, expr'#6*{expr'#6 <- `expr'*`})) + -- if ((s', a) = var_0) + -- if ((z'', val'#4*{val'#4 <- `val'*`}) = var_1) } ;; ../../../../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*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, 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*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_7*` : instr**, `var_6*` : instr**, var_5 : (store, moduleinst), var_4 : (state, ref**), var_3 : (state, ref*), var_2 : (state, val*), var_1 : deftype*, 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?`}))) + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_7))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_6))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_5) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_4) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_3) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_2) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') -- (wf_val: `%`(val_G#3))*{val_G#3 <- `val_G*`} @@ -15679,7 +18721,7 @@ def $instantiate(store : store, module : module, externaddr*) : config -- (wf_data: `%`(DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)))*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`} -- (wf_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*`} -- (wf_start: `%`(START_start(x#6)))?{x#6 <- `x?`} - -- wf_moduleinst: `%`({TYPES $alloctypes(type#6*{type#6 <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr#8*{externaddr#8 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#9*{externaddr#9 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({TYPES var_0, TAGS [], GLOBALS $globalsxa(externaddr#8*{externaddr#8 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#9*{externaddr#9 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#1)))^(i_D#1<|data#7*{data#7 <- `data*`}|){} @@ -15693,21 +18735,22 @@ def $instantiate(store : store, module : module, externaddr*) : config -- if (data#9*{data#9 <- `data*`} = DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`}) -- if (elem#10*{elem#10 <- `elem*`} = ELEM_elem(reftype#519, expr_E#4*{expr_E#4 <- `expr_E*#4`}, elemmode#239)*{elemmode#239 <- `elemmode*`, `expr_E*#4` <- `expr_E**`, reftype#519 <- `reftype*`}) -- if (start#8?{start#8 <- `start?`} = START_start(x#8)?{x#8 <- `x?`}) - -- if (moduleinst_0 = {TYPES $alloctypes(type#8*{type#8 <- `type*`}), TAGS [], GLOBALS $globalsxa(externaddr#11*{externaddr#11 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#12*{externaddr#12 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- if (moduleinst_0 = {TYPES var_1, TAGS [], GLOBALS $globalsxa(externaddr#11*{externaddr#11 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#12*{externaddr#12 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = $evalglobals(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`})) - -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = $evalexprs(z', expr_T#5*{expr_T#5 <- `expr_T*`})) - -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = $evalexprss(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`})) + -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_2) + -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_3) + -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_4) -- if (z''' = `%;%`_state(s''', f)) - -- if ((s'''', moduleinst) = $allocmodule(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`})) - -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2])^(i_D#2<|data#10*{data#10 <- `data*`}|){})) - -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2])^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){})) + -- if ((s'''', moduleinst) = var_5) + -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_6^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`})) + -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_7^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`})) -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $invoke(store : store, funcaddr : funcaddr, val*) : config +relation fun_invoke: `%%%%`(store, 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))]) + 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))])) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val#2)*{val#2 <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#6*{t_2#6 <- `t_2*`}))) -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#7*{t_1#7 <- `t_1*`}), `%`_resulttype(t_2#7*{t_2#7 <- `t_2*`}))) @@ -15771,13 +18814,17 @@ 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 []} +;; ../../../../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 []}) -- 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 + 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 @@ -16060,12 +19107,15 @@ def $exportsd(decl*) : export* } ;; ../../../../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 + rule fun_ordered_case_0{`decl*` : decl*}: + `%%`(decl#1*{decl#1 <- `decl*`}, true) -- if ($importsd(decl#2*{decl#2 <- `decl*`}) = []) + ;; ../../../../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*}: + `%%`(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*`}) = []))) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec relation Context_ok: `|-%:OK`(context) @@ -16077,9 +19127,7 @@ 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 (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 []}) @@ -16090,8 +19138,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*`} @@ -16159,25 +19205,15 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) -- (wf_externtype: `%`(MEM_externtype(memtype)))*{memtype <- `memtype*`} -- (wf_externtype: `%`(TABLE_externtype(tabletype)))*{tabletype <- `tabletype*`} -- (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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16190,7 +19226,6 @@ relation Frame_ok: `%|-%:%`(store, frame, context) -- 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 []}) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) - -- if (|`lct*`| = |`val?*`|) -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16270,7 +19305,7 @@ 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*`}))) -- wf_store: `%`(s) -- wf_context: `%`(C) @@ -16278,16 +19313,13 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- (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*`}))) - -- if (|`init*`| = |`t*`|) -- (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*`}))) -- 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*`| = |`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*`}))) + -- 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}: @@ -16394,7 +19426,6 @@ relation Structinst_ok: `%|-%:OK`(store, structinst) -- wf_structinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16416,10 +19447,8 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) -- wf_store: `%`(s) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- 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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16440,21 +19469,16 @@ 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|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt)) -- 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)) ;; ../../../../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|) -- wf_store: `%`(s) -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(), zt))) @@ -16463,8 +19487,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)) @@ -16476,23 +19498,34 @@ 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 + 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) = 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 $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 _{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) -- wf_fieldval: `%`(fv_1) -- wf_store: `%`(s) -- wf_fieldval: `%`(fv_2) - -- if $NotImmutReachable(fv_1, s, fv_2) + -- if var_0 + -- fun_NotImmutReachable: `%%%%`(fv_1, s, fv_2, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Store_ok: `|-%:OK`(store) @@ -16509,19 +19542,12 @@ relation Store_ok: `|-%:OK`(store) -- (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*`}}) - -- 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*`} @@ -16601,8 +19627,6 @@ relation Extend_structinst: `%<=%`(structinst, structinst) -- wf_structinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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?*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16614,7 +19638,6 @@ relation Extend_arrayinst: `%<=%`(arrayinst, arrayinst) -- wf_arrayinst: `%`({TYPE dt, FIELDS fv'*{fv' <- `fv'*`}}) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (|`fv*`| = |`fv'*`|) -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16631,35 +19654,15 @@ relation Extend_store: `%<=%`(store, store) `%<=%`(s, s') -- wf_store: `%`(s) -- wf_store: `%`(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|){} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -16753,7 +19756,6 @@ relation NotationTypingInstrScheme: `%|-%:%`(context, instr*, instrtype) -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) -- wf_globaltype: `%`(`%%`_globaltype(?(mut), t)) - -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(mut), t)) ;; ../../../../specification/wasm-3.0/X.2-notation.typing.spectec:29.1-32.78 @@ -16895,7 +19897,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 @@ -16945,8 +19948,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 @@ -18433,10 +21437,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 @@ -18607,7 +21612,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))] @@ -18620,8 +21626,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 @@ -18785,7 +21792,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 { @@ -18844,10 +21852,12 @@ grammar TfNmag(N : N) : 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)) + prod{var_0 : m} "nan" => NAN_fNmag(var_0) + -- fun_canon_: `%%`(N, var_0) ;; ../../../../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))))) + prod{n : n, var_0 : nat?} {{"nan:0x"} {n:Thexnum}} => NAN_fNmag(n) + -- if ((1 <= n) /\ (n < (2 ^ !(var_0)))) + -- fun_signif: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar TfN(N : N) : fN @@ -19115,7 +22125,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 @@ -20302,9 +23313,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* @@ -20465,8 +23477,8 @@ 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_1 : bool, 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*`})) @@ -20479,7 +23491,9 @@ grammar Tmodule : module -- 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 var_1 + -- fun_ordered: `%%`(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/07-sideconditions.il b/spectec/test-middlend/specification.exp/10-sideconditions.il similarity index 55% rename from spectec/test-middlend/specification.exp/07-sideconditions.il rename to spectec/test-middlend/specification.exp/10-sideconditions.il index d53f991c86..cea5af435d 100644 --- a/spectec/test-middlend/specification.exp/07-sideconditions.il +++ b/spectec/test-middlend/specification.exp/10-sideconditions.il @@ -27,7 +27,7 @@ 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'*`})) + 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 @@ -38,7 +38,7 @@ 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'*`})) + def $prod{n : nat, `n'*` : n*}([n] ++ n'#2*{n'#2 <- `n'*`}) = (n * $prod(n'*{n' <- `n'*`})) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -58,7 +58,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 +69,7 @@ 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^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) } ;; ../../../../specification/wasm-3.0/0.3-aux.seq.spectec @@ -77,7 +77,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 +93,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 +104,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 +113,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 +126,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 +135,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 +148,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 @@ -244,32 +244,70 @@ syntax i64 = iN syntax i128 = iN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $signif(N : N) : nat? +relation fun_signif_before_fun_signif_case_2: `%`(N) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $signif(32) = ?(23) + rule fun_signif_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $signif(64) = ?(52) - def $signif{x0 : N}(x0) = ?() - -- otherwise + rule fun_signif_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $expon(N : N) : nat? +relation fun_signif: `%%`(N, nat?) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $expon(32) = ?(8) + rule fun_signif_case_0: + `%%`(32, ?(23)) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $expon(64) = ?(11) - def $expon{x0 : N}(x0) = ?() - -- otherwise + rule fun_signif_case_1: + `%%`(64, ?(52)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_signif_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_signif_before_fun_signif_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_expon_before_fun_expon_case_2: `%`(N) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_expon: `%%`(N, nat?) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_0: + `%%`(32, ?(8)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_1: + `%%`(64, ?(11)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_expon_before_fun_expon_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $M(N : N) : nat +relation fun_M: `%%`(N, nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $M{N : nat}(N) = !($signif(N)) + rule fun_M_case_0{N : nat, var_0 : nat?}: + `%%`(N, !(var_0)) + -- if (var_0 =/= ?()) + -- fun_signif: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $E(N : N) : nat +relation fun_E: `%%`(N, nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $E{N : nat}(N) = !($expon(N)) + rule fun_E_case_0{N : nat, var_0 : nat?}: + `%%`(N, !(var_0)) + -- if (var_0 =/= ?()) + -- fun_expon: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax exp = int @@ -284,23 +322,28 @@ syntax fNmag = ;; ../../../../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}: + rule fNmag_case_0{N : N, m : m, exp : exp, var_1 : nat, var_0 : nat}: `%%`(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))))) + -- if ((m < (2 ^ var_0)) /\ ((((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= exp) /\ (exp <= (((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) + -- fun_E: `%%`(N, var_1) + -- fun_M: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_1{N : N, exp : exp, m : m}: + rule fNmag_case_1{N : N, exp : exp, m : m, var_1 : nat, var_0 : nat}: `%%`(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)) + -- if ((m < (2 ^ var_0)) /\ (((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = exp)) + -- fun_E: `%%`(N, var_1) + -- fun_M: `%%`(N, var_0) ;; ../../../../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}: + rule fNmag_case_3{N : N, m : m, var_0 : nat}: `%%`(N, NAN_fNmag(m)) - -- if ((1 <= m) /\ (m < (2 ^ $M(N)))) + -- if ((1 <= m) /\ (m < (2 ^ var_0))) + -- fun_M: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax fN = @@ -326,27 +369,33 @@ syntax f32 = fN syntax f64 = fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $fzero(N : N) : fN +relation fun_fzero: `%%`(N, fN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fzero{N : nat}(N) = POS_fN(SUBNORM_fNmag(0)) + rule fun_fzero_case_0{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 +relation fun_fnat: `%%%`(N, 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))) + rule fun_fnat_case_0{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 +relation fun_fone: `%%`(N, fN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fone{N : nat}(N) = POS_fN(NORM_fNmag(1, (0 : nat <:> int))) + rule fun_fone_case_0{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 +relation fun_canon_: `%%`(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)) + rule fun_canon__case_0{N : nat, var_0 : nat?}: + `%%`(N, (2 ^ (((!(var_0) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + -- if (var_0 =/= ?()) + -- fun_signif: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax vN = uN @@ -381,45 +430,63 @@ 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, b : byte}([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*`})) + -- if (|`var_0*`| = |`ch*`|) + -- (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, b : byte}: + `%%`([ch], [b]) -- wf_byte: `%`(b) -- wf_byte: `%`(`%`_byte($proj_char_0(ch).0)) -- if ($proj_char_0(ch).0 < 128) -- if (`%`_byte($proj_char_0(ch).0) = b) - ;; ../../../../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]) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(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))) - ;; ../../../../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)) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(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))) - ;; ../../../../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)) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_4, var_2) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(b_3) -- wf_byte: `%`(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))) + -- 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)) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -434,10 +501,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 @@ -521,9 +589,9 @@ 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*`}) + 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*{xx <- `xx*`}) = $funcsxx(xx*{xx <- `xx*`}) + 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 @@ -534,9 +602,9 @@ 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*`}) + 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*{xx <- `xx*`}) = $globalsxx(xx*{xx <- `xx*`}) + 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 @@ -547,9 +615,9 @@ 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*`}) + 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*{xx <- `xx*`}) = $tablesxx(xx*{xx <- `xx*`}) + 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 @@ -560,9 +628,9 @@ 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*`}) + 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*{xx <- `xx*`}) = $memsxx(xx*{xx <- `xx*`}) + 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 @@ -573,9 +641,9 @@ 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*`}) + 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*{xx <- `xx*`}) = $tagsxx(xx*{xx <- `xx*`}) + 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 @@ -610,97 +678,128 @@ relation wf_free: `%`(free) -- (wf_uN: `%%`(32, var_9))*{var_9 <- var_9} ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_opt(free?) : free +relation fun_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 []} + rule fun_free_opt_case_0: + `%%`(?(), {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 + rule fun_free_opt_case_1{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 []} +;; ../../../../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 []}) -- 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 + 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 -def $free_typeidx(typeidx : typeidx) : free +relation fun_free_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 []} + rule fun_free_typeidx_case_0{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 +relation fun_free_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 []} + rule fun_free_funcidx_case_0{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 +relation fun_free_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 []} + rule fun_free_globalidx_case_0{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 +relation fun_free_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 []} + rule fun_free_tableidx_case_0{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 +relation fun_free_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 []} + rule fun_free_memidx_case_0{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 +relation fun_free_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 []} + rule fun_free_elemidx_case_0{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 +relation fun_free_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 []} + rule fun_free_dataidx_case_0{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 +relation fun_free_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 []} + rule fun_free_localidx_case_0{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 +relation fun_free_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 []} + rule fun_free_labelidx_case_0{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 +relation fun_free_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]} + rule fun_free_tagidx_case_0{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 +relation fun_free_externidx: `%%`(externidx, free) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{funcidx : uN}(FUNC_externidx(funcidx)) = $free_funcidx(funcidx) + rule fun_free_externidx_case_0{funcidx : uN, var_0 : free}: + `%%`(FUNC_externidx(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{globalidx : uN}(GLOBAL_externidx(globalidx)) = $free_globalidx(globalidx) + rule fun_free_externidx_case_1{globalidx : uN, var_0 : free}: + `%%`(GLOBAL_externidx(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{tableidx : uN}(TABLE_externidx(tableidx)) = $free_tableidx(tableidx) + rule fun_free_externidx_case_2{tableidx : uN, var_0 : free}: + `%%`(TABLE_externidx(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{memidx : uN}(MEM_externidx(memidx)) = $free_memidx(memidx) + rule fun_free_externidx_case_3{memidx : uN, var_0 : free}: + `%%`(MEM_externidx(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{tagidx : uN}(TAG_externidx(tagidx)) = $free_tagidx(tagidx) + rule fun_free_externidx_case_4{tagidx : uN, var_0 : free}: + `%%`(TAG_externidx(tagidx), var_0) + -- fun_free_tagidx: `%%`(tagidx, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = @@ -718,6 +817,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 @@ -730,6 +833,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 @@ -826,6 +935,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 { @@ -1016,11 +1183,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 @@ -1036,6 +1213,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 @@ -1051,6 +1234,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 @@ -1063,75 +1250,87 @@ syntax Cnn = | V128 ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $ANYREF : reftype +relation fun_ANYREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) + rule fun_ANYREF_case_0: + `%`(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 +relation fun_EQREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) + rule fun_EQREF_case_0: + `%`(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 +relation fun_I31REF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) + rule fun_I31REF_case_0: + `%`(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 +relation fun_STRUCTREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) + rule fun_STRUCTREF_case_0: + `%`(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 +relation fun_ARRAYREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) + rule fun_ARRAYREF_case_0: + `%`(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 +relation fun_FUNCREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) + rule fun_FUNCREF_case_0: + `%`(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 +relation fun_EXNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) + rule fun_EXNREF_case_0: + `%`(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 +relation fun_EXTERNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) + rule fun_EXTERNREF_case_0: + `%`(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 +relation fun_NULLREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) + rule fun_NULLREF_case_0: + `%`(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 +relation fun_NULLFUNCREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) + rule fun_NULLFUNCREF_case_0: + `%`(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 +relation fun_NULLEXNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) + rule fun_NULLEXNREF_case_0: + `%`(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 +relation fun_NULLEXTERNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) + rule fun_NULLEXTERNREF_case_0: + `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1139,6 +1338,10 @@ 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 @@ -1148,6 +1351,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 @@ -1158,6 +1379,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 @@ -1264,35 +1495,95 @@ relation wf_moduletype: `%`(moduletype) -- (wf_externtype: `%`(`externtype*_0`))*{`externtype*_0` <- `externtype*_0`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $IN(N : N) : Inn? +relation fun_IN_before_fun_IN_case_2: `%`(N) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $IN(32) = ?(I32_Inn) + rule fun_IN_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $IN(64) = ?(I64_Inn) - def $IN{x0 : N}(x0) = ?() - -- otherwise + rule fun_IN_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $FN(N : N) : Fnn? +relation fun_IN: `%%`(N, Inn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FN(32) = ?(F32_Fnn) + rule fun_IN_case_0: + `%%`(32, ?(I32_Inn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FN(64) = ?(F64_Fnn) - def $FN{x0 : N}(x0) = ?() - -- otherwise + rule fun_IN_case_1: + `%%`(64, ?(I64_Inn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_IN_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_IN_before_fun_IN_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $JN(N : N) : Jnn? +relation fun_FN_before_fun_FN_case_2: `%`(N) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(8) = ?(I8_Jnn) + rule fun_FN_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_FN: `%%`(N, Fnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(16) = ?(I16_Jnn) + rule fun_FN_case_0: + `%%`(32, ?(F32_Fnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(32) = ?(I32_Jnn) + rule fun_FN_case_1: + `%%`(64, ?(F64_Fnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(64) = ?(I64_Jnn) - def $JN{x0 : N}(x0) = ?() - -- otherwise + rule fun_FN_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_FN_before_fun_FN_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_JN_before_fun_JN_case_4: `%`(N) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_3: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_2: + `%`(32) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_1: + `%`(16) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_0: + `%`(8) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_JN: `%%`(N, Jnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_0: + `%%`(8, ?(I8_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_1: + `%%`(16, ?(I16_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_2: + `%%`(32, ?(I32_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_3: + `%%`(64, ?(I64_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_4{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_JN_before_fun_JN_case_4: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $size(numtype : numtype) : nat @@ -1320,62 +1611,162 @@ 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{packtype : packtype}((packtype : packtype <: lanetype)) = $psize(packtype) + 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(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? +relation fun_zsize_before_fun_zsize_case_7: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_6: + `%`(I16_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{numtype : numtype}((numtype : numtype <: storagetype)) = ?($size(numtype)) + rule fun_zsize_case_5: + `%`(I8_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{vectype : vectype}((vectype : vectype <: storagetype)) = ?($vsize(vectype)) + rule fun_zsize_case_4: + `%`(V128_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize{packtype : packtype}((packtype : packtype <: storagetype)) = ?($psize(packtype)) - def $zsize{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_zsize_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_zsize: `%%`(storagetype, nat?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_0: + `%%`(I32_storagetype, ?($size(I32_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_1: + `%%`(I64_storagetype, ?($size(I64_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_2: + `%%`(F32_storagetype, ?($size(F32_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_3: + `%%`(F64_storagetype, ?($size(F64_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_4: + `%%`(V128_storagetype, ?($vsize(V128_vectype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_5: + `%%`(I8_storagetype, ?($psize(I8_packtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_6: + `%%`(I16_storagetype, ?($psize(I16_packtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_7{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_zsize_before_fun_zsize_case_7: `%`(x0) ;; ../../../../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? +relation fun_inv_isize_before_fun_inv_isize_case_2: `%`(nat) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_isize(32) = ?(I32_Inn) + rule fun_inv_isize_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_isize(64) = ?(I64_Inn) - def $inv_isize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_inv_isize_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_jsize(nat : nat) : Jnn? +relation fun_inv_isize: `%%`(nat, Inn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize(8) = ?(I8_Jnn) + rule fun_inv_isize_case_0: + `%%`(32, ?(I32_Inn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize(16) = ?(I16_Jnn) + rule fun_inv_isize_case_1: + `%%`(64, ?(I64_Inn)) + ;; ../../../../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)} + rule fun_inv_isize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_inv_isize_before_fun_inv_isize_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_fsize(nat : nat) : Fnn? +relation fun_inv_jsize: `%%`(nat, Jnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_fsize(32) = ?(F32_Fnn) + rule fun_inv_jsize_case_0: + `%%`(8, ?(I8_Jnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_fsize(64) = ?(F64_Fnn) - def $inv_fsize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_inv_jsize_case_1: + `%%`(16, ?(I16_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_jsize_case_2{n : nat, var_0 : Inn?}: + `%%`(n, $Jnn_addrtype(iter_val#1)?{iter_val#1 <- var_0}) + -- fun_inv_isize: `%%`(n, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(nat) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_fsize: `%%`(nat, Fnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_0: + `%%`(32, ?(F32_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_1: + `%%`(64, ?(F64_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $sizenn(numtype : numtype) : nat @@ -1420,591 +1811,1313 @@ 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? +relation fun_inv_jsizenn: `%%`(nat, Jnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsizenn{n : nat}(n) = $inv_jsize(n) + rule fun_inv_jsizenn_case_0{n : nat, var_0 : Jnn?}: + `%%`(n, var_0) + -- fun_inv_jsize: `%%`(n, var_0) ;; ../../../../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{packtype : packtype}((packtype : packtype <: lanetype)) = I32_numtype - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $unpack(storagetype : storagetype) : valtype + def $lunpack(I64_lanetype) = I64_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack{valtype : valtype}((valtype : valtype <: storagetype)) = valtype + def $lunpack(F32_lanetype) = F32_numtype ;; ../../../../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? + def $lunpack(F64_lanetype) = F64_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack{numtype : numtype}((numtype : numtype <: storagetype)) = ?(numtype) + def $lunpack(I8_lanetype) = I32_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 + def $lunpack(I16_lanetype) = I32_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $vunpack(storagetype : storagetype) : vectype? +relation fun_unpack: `%%`(storagetype, valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $vunpack{vectype : vectype}((vectype : vectype <: storagetype)) = ?(vectype) - def $vunpack{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_unpack_case_0: + `%%`(BOT_storagetype, BOT_valtype) -;; ../../../../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) + rule fun_unpack_case_1{`null?` : null?, heaptype : heaptype}: + `%%`(REF_storagetype(`null?`, heaptype), REF_valtype(`null?`, heaptype)) + ;; ../../../../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 + rule fun_unpack_case_2: + `%%`(V128_storagetype, V128_valtype) -;; ../../../../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) + rule fun_unpack_case_3: + `%%`(F64_storagetype, F64_valtype) -;; ../../../../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)) + rule fun_unpack_case_4: + `%%`(F32_storagetype, F32_valtype) + ;; ../../../../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 fun_unpack_case_5: + `%%`(I64_storagetype, I64_valtype) -;; ../../../../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 + rule fun_unpack_case_6: + `%%`(I32_storagetype, I32_valtype) -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_7: + `%%`(I8_storagetype, I32_valtype) + -- wf_valtype: `%`(I32_valtype) -;; ../../../../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 + rule fun_unpack_case_8: + `%%`(I16_storagetype, I32_valtype) + -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { +relation fun_nunpack_before_fun_nunpack_case_6: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_5: + `%`(I16_storagetype) -;; ../../../../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 + rule fun_nunpack_case_4: + `%`(I8_storagetype) -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_3: + `%`(F64_storagetype) -;; ../../../../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 + rule fun_nunpack_case_2: + `%`(F32_storagetype) -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_1: + `%`(I64_storagetype) -;; ../../../../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 + rule fun_nunpack_case_0: + `%`(I32_storagetype) ;; ../../../../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*`}) -} +relation fun_nunpack: `%%`(storagetype, numtype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_0: + `%%`(I32_storagetype, ?(I32_numtype)) -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_1: + `%%`(I64_storagetype, ?(I64_numtype)) -;; ../../../../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 + rule fun_nunpack_case_2: + `%%`(F32_storagetype, ?(F32_numtype)) -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_3: + `%%`(F64_storagetype, ?(F64_numtype)) -;; ../../../../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*, `tv'*` : typevar*, `tu'*` : typeuse*}([_IDX_typevar(x)] ++ tv*{tv <- `tv*`}, [tu_1] ++ tu*{tu <- `tu*`}) = ?(([_IDX_typevar(x)] ++ tv'*{tv' <- `tv'*`}, [tu_1] ++ tu'*{tu' <- `tu'*`})) - -- (wf_typevar: `%`(tv'))*{tv' <- `tv'*`} - -- (wf_typeuse: `%`(tu'))*{tu' <- `tu'*`} - -- wf_typevar: `%`(_IDX_typevar(x)) - -- if ((tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}) = !($minus_recs(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}))) - def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() - -- otherwise -} + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_4: + `%%`(I8_storagetype, ?(I32_numtype)) -;; ../../../../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 + rule fun_nunpack_case_5: + `%%`(I16_storagetype, ?(I32_numtype)) -;; ../../../../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 + rule fun_nunpack_case_6{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_nunpack_before_fun_nunpack_case_6: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_vectype(vectype : vectype, typevar*, typeuse*) : vectype +relation fun_vunpack_before_fun_vunpack_case_1: `%`(storagetype) ;; ../../../../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 + rule fun_vunpack_case_0: + `%`(V128_storagetype) ;; ../../../../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) +relation fun_vunpack: `%%`(storagetype, vectype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_vunpack_case_0: + `%%`(V128_storagetype, ?(V128_vectype)) -;; ../../../../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*, `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*`})) - -- (wf_typevar: `%`(tv'))*{tv' <- `tv'*`} - -- (wf_typeuse: `%`(tu'))*{tu' <- `tu'*`} - -- if ((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 + rule fun_vunpack_case_1{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_vunpack_before_fun_vunpack_case_1: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_addrtype(addrtype : addrtype, typevar*, typeuse*) : addrtype +relation fun_cunpack_before_fun_cunpack_case_13: `%`(storagetype) ;; ../../../../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 + rule fun_cunpack_case_12: + `%`(I16_storagetype) -;; ../../../../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*`}) + rule fun_cunpack_case_11: + `%`(I8_storagetype) -;; ../../../../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*`}))) + rule fun_cunpack_case_10: + `%`(F64_storagetype) -;; ../../../../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)) + rule fun_cunpack_case_9: + `%`(F32_storagetype) -;; ../../../../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*`}))) + rule fun_cunpack_case_8: + `%`(I64_storagetype) -;; ../../../../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*`}))) + rule fun_cunpack_case_7: + `%`(I32_storagetype) + ;; ../../../../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 fun_cunpack_case_6: + `%`(I16_storagetype) + ;; ../../../../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_cunpack_case_5: + `%`(I8_storagetype) + ;; ../../../../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_cunpack_case_4: + `%`(V128_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_cunpack: `%%`(storagetype, consttype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_0: + `%%`(I32_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_1: + `%%`(I64_storagetype, ?(I64_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_2: + `%%`(F32_storagetype, ?(F32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_3: + `%%`(F64_storagetype, ?(F64_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_4: + `%%`(V128_storagetype, ?(V128_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_5: + `%%`(I8_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_6: + `%%`(I16_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_7: + `%%`(I32_storagetype, ?($consttype_numtype($lunpack(I32_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_8: + `%%`(I64_storagetype, ?($consttype_numtype($lunpack(I64_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_9: + `%%`(F32_storagetype, ?($consttype_numtype($lunpack(F32_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_10: + `%%`(F64_storagetype, ?($consttype_numtype($lunpack(F64_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_11: + `%%`(I8_storagetype, ?($consttype_numtype($lunpack(I8_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_12: + `%%`(I16_storagetype, ?($consttype_numtype($lunpack(I16_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_13{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_cunpack_before_fun_cunpack_case_13: `%`(x0) + +;; ../../../../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($numtype_addrtype(at_1)) <= $size($numtype_addrtype(at_2))) then at_1 else at_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_diffrt: `%%%`(reftype, reftype, reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_diffrt_case_0{`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 + rule fun_diffrt_case_1{`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 fun_as_deftype_before_fun_as_deftype_case_1: `%`(typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_0{rectype : rectype, n : n}: + `%`(_DEF_typeuse(rectype, n)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_as_deftype: `%%`(typeuse, deftype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_0{rectype : rectype, n : n}: + `%%`(_DEF_typeuse(rectype, n), ?(_DEF_deftype(rectype, n))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_1{x0 : typeuse}: + `%%`(x0, ?()) + -- ~ fun_as_deftype_before_fun_as_deftype_case_1: `%`(x0) + +;; ../../../../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 +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 +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 +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 +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 +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:401.6-401.17 +relation fun_minus_recs_before_fun_minus_recs_case_3: `%%`(typevar*, typeuse*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%`([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) + -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} + -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} + -- wf_typevar: `%`(_IDX_typevar(x)) + -- if (var_0 =/= ?()) + -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_0: + `%%`([], []) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_0: + `%%%`([], [], ?(([], []))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}, var_0) + -- fun_minus_recs: `%%%`(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, 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'*`}))) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) + -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} + -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} + -- wf_typevar: `%`(_IDX_typevar(x)) + -- if (var_0 =/= ?()) + -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_3{x0 : typevar*, x1 : typeuse*}: + `%%%`(x0, x1, ?()) + -- ~ fun_minus_recs_before_fun_minus_recs_case_3: `%%`(x0, x1) +} + +;; ../../../../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#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#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#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.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)) + -- if (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)) + -- if (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))) + -- if (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))) + -- if (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_1 : heaptype, 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#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, var_1) + -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) + +;; ../../../../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#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:345.6-345.20 + rule fun_subst_valtype_case_1{`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:345.6-345.20 + rule fun_subst_valtype_case_2{`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:345.6-345.20 + rule fun_subst_valtype_case_3{`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:345.6-345.20 + rule fun_subst_valtype_case_4{`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: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#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}, $valtype_reftype(var_0)) + -- fun_subst_reftype: `%%%%`(REF_reftype(`null?`, heaptype), tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `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#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}, BOT_valtype) + -- wf_valtype: `%`(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#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(BOT_valtype, tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `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#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(REF_valtype(`null?`, heaptype), tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `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#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(V128_valtype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `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#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F64_valtype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `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#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F32_valtype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `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#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I64_valtype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `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#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I32_valtype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `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#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:348.6-348.24 + rule fun_subst_storagetype_case_8{`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.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_1 : storagetype, var_0 : storagetype}: + `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_storagetype: `%%%%`(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, var_1) + -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) + +;; ../../../../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_1*` : fieldtype*, `var_0*` : fieldtype*}: + `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- if (|`var_1*`| = |`ft*`|) + -- (fun_subst_fieldtype: `%%%%`(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, var_1))*{var_1 <- `var_1*`, ft#2 <- `ft*`} + -- if (|`var_0*`| = |`ft*`|) + -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) + + ;; ../../../../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_1 : fieldtype, var_0 : fieldtype}: + `%%%%`(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, ARRAY_comptype(var_0)) + -- fun_subst_fieldtype: `%%%%`(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}, var_1) + -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_comptype: `%`(ARRAY_comptype(var_1)) + + ;; ../../../../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_3*` : valtype*, `var_2*` : valtype*, `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#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- if (|`var_3*`| = |`t_2*`|) + -- (fun_subst_valtype: `%%%%`(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_3))*{var_3 <- `var_3*`, t_2#2 <- `t_2*`} + -- if (|`var_2*`| = |`t_1*`|) + -- (fun_subst_valtype: `%%%%`(t_1#2, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}, var_2))*{var_2 <- `var_2*`, t_1#2 <- `t_1*`} + -- if (|`var_1*`| = |`t_2*`|) + -- (fun_subst_valtype: `%%%%`(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, t_2 <- `t_2*`} + -- if (|`var_0*`| = |`t_1*`|) + -- (fun_subst_valtype: `%%%%`(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, t_1 <- `t_1*`} + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) + +;; ../../../../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_3 : comptype, `var_2*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: + `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#4*{tu'#4 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- fun_subst_comptype: `%%%%`(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, var_3) + -- if (|`var_2*`| = |`tu'*`|) + -- (fun_subst_typeuse: `%%%%`(tu'#5, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}, var_2))*{var_2 <- `var_2*`, tu'#5 <- `tu'*`} + -- fun_subst_comptype: `%%%%`(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1) + -- if (|`var_0*`| = |`tu'*`|) + -- (fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, tu' <- `tu'*`} + -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) + +;; ../../../../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*, `tv'*` : typevar*, `tu'*` : typeuse*, var_1 : (typevar*, typeuse*)?, `var_0*` : subtype*}: + `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) + -- if (|`var_0*`| = |`st*`|) + -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} + -- (wf_typevar: `%`(tv'#4))*{tv'#4 <- `tv'*`} + -- (wf_typeuse: `%`(tu'#6))*{tu'#6 <- `tu'*`} + -- if (var_1 =/= ?()) + -- if ((tv'#5*{tv'#5 <- `tv'*`}, tu'#7*{tu'#7 <- `tu'*`}) = !(var_1)) + +;; ../../../../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#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `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 +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 + +;; ../../../../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#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `tu*`}, var_0) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, 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 + rule fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : valtype, var_0 : valtype}: + `%%%%`(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_valtype: `%%%%`(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}, var_1) + -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_memtype: `%%%%`(memtype, typevar*, typeuse*, memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_memtype_case_0{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)) + +;; ../../../../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_1 : reftype, var_0 : reftype}: + `%%%%`(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- fun_subst_reftype: `%%%%`(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}, var_1) + -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) + +;; ../../../../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_1 : tagtype, var_0 : tagtype}: + `%%%%`(TAG_externtype(jt), tv#75*{tv#75 <- `tv*`}, tu#75*{tu#75 <- `tu*`}, TAG_externtype(var_0)) + -- fun_subst_tagtype: `%%%%`(jt, tv#76*{tv#76 <- `tv*`}, tu#76*{tu#76 <- `tu*`}, var_1) + -- fun_subst_tagtype: `%%%%`(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(TAG_externtype(var_1)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_1{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : globaltype, var_0 : globaltype}: + `%%%%`(GLOBAL_externtype(gt), tv#77*{tv#77 <- `tv*`}, tu#77*{tu#77 <- `tu*`}, GLOBAL_externtype(var_0)) + -- fun_subst_globaltype: `%%%%`(gt, tv#78*{tv#78 <- `tv*`}, tu#78*{tu#78 <- `tu*`}, var_1) + -- fun_subst_globaltype: `%%%%`(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(GLOBAL_externtype(var_1)) + ;; ../../../../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_1 : tabletype, var_0 : tabletype}: + `%%%%`(TABLE_externtype(tt), tv#79*{tv#79 <- `tv*`}, tu#79*{tu#79 <- `tu*`}, TABLE_externtype(var_0)) + -- fun_subst_tabletype: `%%%%`(tt, tv#80*{tv#80 <- `tv*`}, tu#80*{tu#80 <- `tu*`}, var_1) + -- fun_subst_tabletype: `%%%%`(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(TABLE_externtype(var_1)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_3{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : memtype, var_0 : memtype}: + `%%%%`(MEM_externtype(mt), tv#81*{tv#81 <- `tv*`}, tu#81*{tu#81 <- `tu*`}, MEM_externtype(var_0)) + -- fun_subst_memtype: `%%%%`(mt, tv#82*{tv#82 <- `tv*`}, tu#82*{tu#82 <- `tu*`}, var_1) + -- fun_subst_memtype: `%%%%`(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(MEM_externtype(var_1)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_4{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_1 : typeuse, var_0 : typeuse}: + `%%%%`(FUNC_externtype(tu'), tv#83*{tv#83 <- `tv*`}, tu#83*{tu#83 <- `tu*`}, FUNC_externtype(var_0)) + -- fun_subst_typeuse: `%%%%`(tu', tv#84*{tv#84 <- `tv*`}, tu#84*{tu#84 <- `tu*`}, var_1) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(FUNC_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_moduletype(moduletype : moduletype, typevar*, typeuse*) : moduletype +relation fun_subst_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_moduletype_case_0{`xt_1*` : externtype*, `xt_2*` : externtype*, `tv*` : typevar*, `tu*` : typeuse*, `var_3*` : externtype*, `var_2*` : externtype*, `var_1*` : externtype*, `var_0*` : externtype*}: + `%%%%`(`%->%`_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(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- if (|`var_3*`| = |`xt_2*`|) + -- (fun_subst_externtype: `%%%%`(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`}, var_3))*{var_3 <- `var_3*`, xt_2#2 <- `xt_2*`} + -- if (|`var_2*`| = |`xt_1*`|) + -- (fun_subst_externtype: `%%%%`(xt_1#2, tv#86*{tv#86 <- `tv*`}, tu#86*{tu#86 <- `tu*`}, var_2))*{var_2 <- `var_2*`, xt_1#2 <- `xt_1*`} + -- if (|`var_1*`| = |`xt_2*`|) + -- (fun_subst_externtype: `%%%%`(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, xt_2 <- `xt_2*`} + -- if (|`var_0*`| = |`xt_1*`|) + -- (fun_subst_externtype: `%%%%`(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, xt_1 <- `xt_1*`} + -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_all_valtype(valtype : valtype, typeuse*) : valtype +relation fun_subst_all_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: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#503*{valtype#503 <- `valtype*`}), var_0) + -- if (|`var_1*`| = |`valtype*`|) + -- (fun_free_valtype: `%%`(valtype, var_1))*{var_1 <- `var_1*`, valtype <- `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{var_0 : free}: + `%%`(I8_storagetype, var_0) + -- fun_free_packtype: `%%`(I8_packtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_8{var_0 : free}: + `%%`(I16_storagetype, var_0) + -- fun_free_packtype: `%%`(I16_packtype, var_0) + +;; ../../../../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#5?{mut#5 <- `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) + -- if (|`var_1*`| = |`fieldtype*`|) + -- (fun_free_fieldtype: `%%`(fieldtype, var_1))*{var_1 <- `var_1*`, fieldtype <- `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#3?{final#3 <- `final?`}, typeuse#1*{typeuse#1 <- `typeuse*`}, comptype), var_0 +++ var_2) + -- fun_free_comptype: `%%`(comptype, var_2) + -- if (|`var_1*`| = |`typeuse*`|) + -- (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#9*{subtype#9 <- `subtype*`})), var_0) + -- if (|`var_1*`| = |`subtype*`|) + -- (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 -def $free_tagtype(tagtype : tagtype) : free +relation fun_free_tagtype: `%%`(tagtype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_tagtype{deftype : deftype}((deftype : deftype <: typeuse)) = $free_deftype(deftype) + 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 -def $free_globaltype(globaltype : globaltype) : free +relation fun_free_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) + rule fun_free_globaltype_case_0{`mut?` : mut?, valtype : valtype, var_0 : free}: + `%%`(`%%`_globaltype(mut#6?{mut#6 <- `mut?`}, valtype), var_0) + -- fun_free_valtype: `%%`(valtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_memtype(memtype : memtype) : free +relation fun_free_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) + rule fun_free_memtype_case_0{addrtype : addrtype, limits : limits, var_0 : free}: + `%%`(`%%PAGE`_memtype(addrtype, limits), var_0) + -- fun_free_addrtype: `%%`(addrtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tabletype(tabletype : tabletype) : free +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_1 : free, var_0 : free}: + `%%`(`%%%`_tabletype(addrtype, limits, reftype), var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype, var_1) + -- fun_free_addrtype: `%%`(addrtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_datatype(datatype : datatype) : free +relation fun_free_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 []} + rule fun_free_datatype_case_0: + `%%`(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 fun_free_elemtype: `%%`(elemtype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_elemtype{reftype : reftype}(reftype) = $free_reftype(reftype) + 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 -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 - def $free_externtype{globaltype : globaltype}(GLOBAL_externtype(globaltype)) = $free_globaltype(globaltype) + 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{memtype : memtype}(MEM_externtype(memtype)) = $free_memtype(memtype) + rule fun_free_externtype_case_2{memtype : memtype, var_0 : free}: + `%%`(MEM_externtype(memtype), var_0) + -- fun_free_memtype: `%%`(memtype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{tabletype : tabletype}(TABLE_externtype(tabletype)) = $free_tabletype(tabletype) + 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{typeuse : typeuse}(FUNC_externtype(typeuse)) = $free_typeuse(typeuse) + 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 -def $free_moduletype(moduletype : moduletype) : free +relation fun_free_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*`}) + 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) + -- if (|`var_3*`| = |`externtype_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) + -- if (|`var_1*`| = |`externtype_1*`|) + -- (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.3-syntax.instructions.spectec syntax num_ = @@ -2016,14 +3129,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? @@ -2054,19 +3167,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_? @@ -2104,19 +3217,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_? @@ -2185,7 +3298,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 = @@ -2208,12 +3321,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? @@ -2264,12 +3377,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? @@ -2298,7 +3411,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 @@ -2333,12 +3446,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? @@ -2364,12 +3477,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 = @@ -2385,7 +3498,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 = @@ -2406,7 +3519,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 = @@ -2418,12 +3531,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__ = @@ -2438,29 +3551,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? @@ -2519,9 +3632,10 @@ relation wf_shape: `%`(shape) -- if (($lsize(lanetype) * $proj_dim_0(dim).0) = 128) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $dim(shape : shape) : dim +relation fun_dim: `%%`(shape, dim) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $dim{Lnn : lanetype, N : nat}(`%X%`_shape(Lnn, `%`_dim(N))) = `%`_dim(N) + rule fun_dim_case_0{Lnn : lanetype, N : nat}: + `%%`(`%X%`_shape(Lnn, `%`_dim(N)), `%`_dim(N)) -- wf_dim: `%`(`%`_dim(N)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -2549,7 +3663,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 = @@ -2615,7 +3729,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 = @@ -2638,12 +3752,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? @@ -2685,42 +3799,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 = @@ -2746,12 +3860,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? @@ -2786,12 +3900,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? @@ -2820,7 +3934,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 @@ -2849,22 +3963,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 = @@ -2886,12 +4000,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? @@ -2921,7 +4035,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 @@ -2958,7 +4072,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__ = @@ -2970,8 +4084,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 @@ -2989,17 +4103,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__ = @@ -3011,8 +4125,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 @@ -3028,7 +4142,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__ = @@ -3040,8 +4154,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 @@ -3057,7 +4171,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 = @@ -3068,7 +4182,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 = @@ -3080,12 +4194,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 = @@ -3097,12 +4211,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__ = @@ -3117,29 +4231,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? @@ -3194,7 +4308,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_ = @@ -3206,7 +4320,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 @@ -3223,7 +4337,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_ = @@ -3235,7 +4349,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 @@ -3461,6 +4575,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 @@ -3645,6 +4769,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 { @@ -4153,11 +5299,12 @@ relation wf_instr: `%`(instr) -- 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*}: + rule instr_case_95{bshape : bshape, `laneidx*` : laneidx*, var_0 : dim}: `%`(VSHUFFLE_instr(bshape, `laneidx*`)) -- wf_bshape: `%`(bshape) -- (wf_uN: `%%`(8, laneidx))*{laneidx <- `laneidx*`} - -- if (`%`_dim(|laneidx*{laneidx <- `laneidx*`}|) = $dim($proj_bshape_0(bshape).0)) + -- if (`%`_dim(|laneidx*{laneidx <- `laneidx*`}|) = var_0) + -- fun_dim: `%%`($proj_bshape_0(bshape).0, var_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__}: @@ -4274,296 +5421,696 @@ relation wf_instr: `%`(instr) syntax expr = instr* ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $memarg0 : memarg +relation fun_memarg0: `%`(memarg) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} + rule fun_memarg0_case_0: + `%`({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 +relation fun_const: `%%%`(consttype, lit_, instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_const_case_0{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 + rule fun_const_case_1{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 + rule fun_const_case_2{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{numtype : numtype, c : num_}((numtype : numtype <: consttype), mk_lit__0_lit_(numtype, c)) = CONST_instr(numtype, c) - -- wf_instr: `%`(CONST_instr(numtype, c)) + rule fun_const_case_3{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{vectype : vectype, c : uN}((vectype : vectype <: consttype), mk_lit__1_lit_(vectype, c)) = VCONST_instr(vectype, c) - -- wf_instr: `%`(VCONST_instr(vectype, c)) + rule fun_const_case_4{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 -def $free_shape(shape : shape) : free +relation fun_free_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) + rule fun_free_shape_case_0{lanetype : lanetype, dim : dim, var_0 : free}: + `%%`(`%X%`_shape(lanetype, dim), var_0) + -- fun_free_lanetype: `%%`(lanetype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_blocktype(blocktype : blocktype) : free +relation fun_free_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?`}) + rule fun_free_blocktype_case_0{`valtype?` : valtype?, `var_1?` : free?, var_0 : free}: + `%%`(_RESULT_blocktype(valtype#505?{valtype#505 <- `valtype?`}), var_0) + -- if ((`var_1?` = ?()) <=> (`valtype?` = ?())) + -- (fun_free_valtype: `%%`(valtype, var_1))?{var_1 <- `var_1?`, valtype <- `valtype?`} + -- fun_free_opt: `%%`(var_1?{var_1 <- `var_1?`}, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{typeidx : uN}(_IDX_blocktype(typeidx)) = $free_typeidx(typeidx) + rule fun_free_blocktype_case_1{typeidx : uN, var_0 : free}: + `%%`(_IDX_blocktype(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_catch(catch : catch) : free +relation fun_free_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) + rule fun_free_catch_case_0{tagidx : uN, labelidx : uN, var_1 : free, var_0 : free}: + `%%`(CATCH_catch(tagidx, labelidx), var_0 +++ var_1) + -- fun_free_labelidx: `%%`(labelidx, var_1) + -- fun_free_tagidx: `%%`(tagidx, var_0) + ;; ../../../../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) + rule fun_free_catch_case_1{tagidx : uN, labelidx : uN, var_1 : free, var_0 : free}: + `%%`(CATCH_REF_catch(tagidx, labelidx), var_0 +++ var_1) + -- fun_free_labelidx: `%%`(labelidx, var_1) + -- fun_free_tagidx: `%%`(tagidx, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{labelidx : uN}(CATCH_ALL_catch(labelidx)) = $free_labelidx(labelidx) + rule fun_free_catch_case_2{labelidx : uN, var_0 : free}: + `%%`(CATCH_ALL_catch(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{labelidx : uN}(CATCH_ALL_REF_catch(labelidx)) = $free_labelidx(labelidx) + rule fun_free_catch_case_3{labelidx : uN, var_0 : free}: + `%%`(CATCH_ALL_REF_catch(labelidx), var_0) + -- fun_free_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'*`}) +;; ../../../../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) -- 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 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 []} +;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_3{`valtype*?` : valtype*?, `var_2*?` : free*?, `var_1?` : free?, var_0 : free}: + `%%`(SELECT_instr(valtype#506*{valtype#506 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`}), var_0) + -- if ((`var_2*?` = ?()) <=> (`valtype*?` = ?())) + -- (if (|`var_2*`| = |`valtype*`|))?{`var_2*` <- `var_2*?`, `valtype*` <- `valtype*?`} + -- (fun_free_valtype: `%%`(valtype, var_2))*{var_2 <- `var_2*`, valtype <- `valtype*`}?{`var_2*` <- `var_2*?`, `valtype*` <- `valtype*?`} + -- if ((`var_2*?` = ?()) <=> (`var_1?` = ?())) + -- (fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1))?{`var_2*` <- `var_2*?`, var_1 <- `var_1?`} + -- fun_free_opt: `%%`(var_1?{var_1 <- `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, var_0 : free}: + `%%`(BR_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_8{labelidx : uN, var_0 : free}: + `%%`(BR_IF_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_9{`labelidx*` : labelidx*, labelidx' : uN, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(BR_TABLE_instr(labelidx#1*{labelidx#1 <- `labelidx*`}, labelidx'), var_0 +++ var_2) + -- fun_free_labelidx: `%%`(labelidx', var_2) + -- if (|`var_1*`| = |`labelidx*`|) + -- (fun_free_labelidx: `%%`(labelidx, var_1))*{var_1 <- `var_1*`, labelidx <- `labelidx*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_10{labelidx : uN, var_0 : free}: + `%%`(BR_ON_NULL_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_11{labelidx : uN, var_0 : free}: + `%%`(BR_ON_NON_NULL_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../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_2 : free, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2), var_0 +++ var_1 +++ var_2) + -- fun_free_reftype: `%%`(reftype_2, var_2) + -- fun_free_reftype: `%%`(reftype_1, var_1) + -- fun_free_labelidx: `%%`(labelidx, 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_2 : free, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2), var_0 +++ var_1 +++ var_2) + -- fun_free_reftype: `%%`(reftype_2, var_2) + -- fun_free_reftype: `%%`(reftype_1, var_1) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_14{funcidx : uN, var_0 : free}: + `%%`(CALL_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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_1 : free, var_0 : free}: + `%%`(CALL_INDIRECT_instr(tableidx, typeuse), var_0 +++ var_1) + -- fun_free_typeuse: `%%`(typeuse, var_1) + -- fun_free_tableidx: `%%`(tableidx, 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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_18{funcidx : uN, var_0 : free}: + `%%`(RETURN_CALL_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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_1 : free, var_0 : free}: + `%%`(RETURN_CALL_INDIRECT_instr(tableidx, typeuse), var_0 +++ var_1) + -- fun_free_typeuse: `%%`(typeuse, var_1) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_21{tagidx : uN, var_0 : free}: + `%%`(THROW_instr(tagidx), var_0) + -- fun_free_tagidx: `%%`(tagidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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_4*` : free*, 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_3) + -- if (|`var_4*`| = |`instr*`|) + -- (fun_free_instr: `%%`(instr, var_4))*{var_4 <- `var_4*`, instr <- `instr*`} + -- fun_free_list: `%%`(var_4*{var_4 <- `var_4*`}, var_3) + -- if (|`var_2*`| = |`catch*`|) + -- (fun_free_catch: `%%`(catch, var_2))*{var_2 <- `var_2*`, catch <- `catch*`} + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, 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_, var_0 : free}: + `%%`(CONST_instr(numtype, numlit), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_25{numtype : numtype, unop : unop_, var_0 : free}: + `%%`(UNOP_instr(numtype, unop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_26{numtype : numtype, binop : binop_, var_0 : free}: + `%%`(BINOP_instr(numtype, binop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_27{numtype : numtype, testop : testop_, var_0 : free}: + `%%`(TESTOP_instr(numtype, testop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_28{numtype : numtype, relop : relop_, var_0 : free}: + `%%`(RELOP_instr(numtype, relop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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__, var_1 : free, var_0 : free}: + `%%`(CVTOP_instr(numtype_1, numtype_2, cvtop), var_0 +++ var_1) + -- fun_free_numtype: `%%`(numtype_2, var_1) + -- fun_free_numtype: `%%`(numtype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_30{vectype : vectype, veclit : uN, var_0 : free}: + `%%`(VCONST_instr(vectype, veclit), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_31{vectype : vectype, vvunop : vvunop, var_0 : free}: + `%%`(VVUNOP_instr(vectype, vvunop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_32{vectype : vectype, vvbinop : vvbinop, var_0 : free}: + `%%`(VVBINOP_instr(vectype, vvbinop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_33{vectype : vectype, vvternop : vvternop, var_0 : free}: + `%%`(VVTERNOP_instr(vectype, vvternop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_34{vectype : vectype, vvtestop : vvtestop, var_0 : free}: + `%%`(VVTESTOP_instr(vectype, vvtestop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_35{shape : shape, vunop : vunop_, var_0 : free}: + `%%`(VUNOP_instr(shape, vunop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_36{shape : shape, vbinop : vbinop_, var_0 : free}: + `%%`(VBINOP_instr(shape, vbinop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_37{shape : shape, vternop : vternop_, var_0 : free}: + `%%`(VTERNOP_instr(shape, vternop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_38{shape : shape, vtestop : vtestop_, var_0 : free}: + `%%`(VTESTOP_instr(shape, vtestop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_39{shape : shape, vrelop : vrelop_, var_0 : free}: + `%%`(VRELOP_instr(shape, vrelop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_40{ishape : ishape, vshiftop : vshiftop_, var_0 : free}: + `%%`(VSHIFTOP_instr(ishape, vshiftop), var_0) + -- fun_free_shape: `%%`($proj_ishape_0(ishape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_41{ishape : ishape, var_0 : free}: + `%%`(VBITMASK_instr(ishape), var_0) + -- fun_free_shape: `%%`($proj_ishape_0(ishape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_42{bshape : bshape, vswizzlop : vswizzlop_, var_0 : free}: + `%%`(VSWIZZLOP_instr(bshape, vswizzlop), var_0) + -- fun_free_shape: `%%`($proj_bshape_0(bshape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_43{bshape : bshape, `laneidx*` : laneidx*, var_0 : free}: + `%%`(VSHUFFLE_instr(bshape, laneidx#1*{laneidx#1 <- `laneidx*`}), var_0) + -- fun_free_shape: `%%`($proj_bshape_0(bshape).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTUNOP_instr(ishape_1, ishape_2, vextunop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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, var_1 : free, var_0 : free}: + `%%`(VNARROW_instr(ishape_1, ishape_2, sx), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VCVTOP_instr(shape_1, shape_2, vcvtop), var_0 +++ var_1) + -- fun_free_shape: `%%`(shape_2, var_1) + -- fun_free_shape: `%%`(shape_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_49{shape : shape, var_0 : free}: + `%%`(VSPLAT_instr(shape), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VEXTRACT_LANE_instr(shape, sx#43187?{sx#43187 <- `sx?`}, laneidx), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_51{shape : shape, laneidx : uN, var_0 : free}: + `%%`(VREPLACE_LANE_instr(shape, laneidx), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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, var_0 : free}: + `%%`(`REF.FUNC`_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_61{typeidx : uN, var_0 : free}: + `%%`(`STRUCT.NEW`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_62{typeidx : uN, var_0 : free}: + `%%`(`STRUCT.NEW_DEFAULT`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(`STRUCT.GET`_instr(sx#43188?{sx#43188 <- `sx?`}, typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_64{typeidx : uN, u32 : uN, var_0 : free}: + `%%`(`STRUCT.SET`_instr(typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_65{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.NEW`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_66{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.NEW_DEFAULT`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_67{typeidx : uN, u32 : uN, var_0 : free}: + `%%`(`ARRAY.NEW_FIXED`_instr(typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_68{typeidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.NEW_DATA`_instr(typeidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_69{typeidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_70{`sx?` : sx?, typeidx : uN, var_0 : free}: + `%%`(`ARRAY.GET`_instr(sx#43189?{sx#43189 <- `sx?`}, typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_71{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.SET`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_73{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.FILL`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`ARRAY.COPY`_instr(typeidx_1, typeidx_2), var_0 +++ var_1) + -- fun_free_typeidx: `%%`(typeidx_2, var_1) + -- fun_free_typeidx: `%%`(typeidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_75{typeidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.INIT_DATA`_instr(typeidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_76{typeidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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*, free : free}(instr*{instr <- `instr*`}) = free[LABELS_free = $shift_labelidxs(free.LABELS_free)] + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_79{localidx : uN, var_0 : free}: + `%%`(`LOCAL.GET`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_80{localidx : uN, var_0 : free}: + `%%`(`LOCAL.SET`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_81{localidx : uN, var_0 : free}: + `%%`(`LOCAL.TEE`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_82{globalidx : uN, var_0 : free}: + `%%`(`GLOBAL.GET`_instr(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_83{globalidx : uN, var_0 : free}: + `%%`(`GLOBAL.SET`_instr(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_84{tableidx : uN, var_0 : free}: + `%%`(`TABLE.GET`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_85{tableidx : uN, var_0 : free}: + `%%`(`TABLE.SET`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_86{tableidx : uN, var_0 : free}: + `%%`(`TABLE.SIZE`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_87{tableidx : uN, var_0 : free}: + `%%`(`TABLE.GROW`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_88{tableidx : uN, var_0 : free}: + `%%`(`TABLE.FILL`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`TABLE.COPY`_instr(tableidx_1, tableidx_2), var_0 +++ var_1) + -- fun_free_tableidx: `%%`(tableidx_2, var_1) + -- fun_free_tableidx: `%%`(tableidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_90{tableidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`TABLE.INIT`_instr(tableidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_91{elemidx : uN, var_0 : free}: + `%%`(`ELEM.DROP`_instr(elemidx), var_0) + -- fun_free_elemidx: `%%`(elemidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(LOAD_instr(numtype, loadop#1?{loadop#1 <- `loadop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(STORE_instr(numtype, storeop#1?{storeop#1 <- `storeop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VLOAD_instr(vectype, vloadop#1?{vloadop#1 <- `vloadop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VSTORE_instr(vectype, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_98{memidx : uN, var_0 : free}: + `%%`(`MEMORY.SIZE`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_99{memidx : uN, var_0 : free}: + `%%`(`MEMORY.GROW`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_100{memidx : uN, var_0 : free}: + `%%`(`MEMORY.FILL`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`MEMORY.COPY`_instr(memidx_1, memidx_2), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx_2, var_1) + -- fun_free_memidx: `%%`(memidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_102{memidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`MEMORY.INIT`_instr(memidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_103{dataidx : uN, var_0 : free}: + `%%`(`DATA.DROP`_instr(dataidx), var_0) + -- fun_free_dataidx: `%%`(dataidx, var_0) + +;; ../../../../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*, free : free, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: + `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- if (|`var_2*`| = |`instr*`|) + -- (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) -- wf_free: `%`(free) - -- if (free = $free_list($free_instr(instr)*{instr <- `instr*`})) + -- if (free = 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*{instr <- `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) + -- if (|`var_1*`| = |`instr*`|) + -- (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.4-syntax.modules.spectec syntax elemmode = @@ -4751,98 +6298,184 @@ 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 fun_free_tag: `%%`(tag, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_tag{tagtype : typeuse}(TAG_tag(tagtype)) = $free_tagtype(tagtype) + 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_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 -def $free_mem(mem : mem) : free +relation fun_free_mem: `%%`(mem, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_mem{memtype : memtype}(MEMORY_mem(memtype)) = $free_memtype(memtype) + rule fun_free_mem_case_0{memtype : memtype, var_0 : free}: + `%%`(MEMORY_mem(memtype), var_0) + -- fun_free_memtype: `%%`(memtype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_table(table : table) : free +relation fun_free_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) + 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_local(local : local) : free +relation fun_free_local: `%%`(local, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) + 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_func(func : func) : free +relation fun_free_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 = []] + rule fun_free_func_case_0{typeidx : uN, `local*` : local*, expr : instr*, var_3 : free, `var_2*` : free*, var_1 : free, var_0 : free}: + `%%`(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr), var_0 +++ var_1 +++ var_3[LOCALS_free = []]) + -- fun_free_block: `%%`(expr, var_3) + -- if (|`var_2*`| = |`local*`|) + -- (fun_free_local: `%%`(local, var_2))*{var_2 <- `var_2*`, local <- `local*`} + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_datamode(datamode : datamode) : free +relation fun_free_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) + rule fun_free_datamode_case_0{memidx : uN, expr : instr*, var_1 : free, var_0 : free}: + `%%`(ACTIVE_datamode(memidx, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_memidx: `%%`(memidx, var_0) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode(PASSIVE_datamode) = {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 []}) -- 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 +relation fun_free_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) + 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_elemmode(elemmode : elemmode) : free +relation fun_free_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) + rule fun_free_elemmode_case_0{tableidx : uN, expr : instr*, var_1 : free, var_0 : free}: + `%%`(ACTIVE_elemmode(tableidx, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_tableidx: `%%`(tableidx, var_0) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} + rule fun_free_elemmode_case_1: + `%%`(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 []} + rule fun_free_elemmode_case_2: + `%%`(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 +relation fun_free_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) + 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) + -- if (|`var_2*`| = |`expr*`|) + -- (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_start(start : start) : free +relation fun_free_start: `%%`(start, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_start{funcidx : uN}(START_start(funcidx)) = $free_funcidx(funcidx) + rule fun_free_start_case_0{funcidx : uN, var_0 : free}: + `%%`(START_start(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_import(import : import) : free +relation fun_free_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) + 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 -def $free_export(export : export) : free +relation fun_free_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) + rule fun_free_export_case_0{name : name, externidx : externidx, var_0 : free}: + `%%`(EXPORT_export(name, externidx), var_0) + -- fun_free_externidx: `%%`(externidx, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_module(module : module) : free +relation fun_free_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*`}) + 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_21*` : free*, var_20 : free, `var_19*` : free*, var_18 : free, `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_8 +++ var_10 +++ var_12 +++ var_14 +++ var_16 +++ var_18 +++ var_20) + -- if (|`var_21*`| = |`export*`|) + -- (fun_free_export: `%%`(export, var_21))*{var_21 <- `var_21*`, export <- `export*`} + -- fun_free_list: `%%`(var_21*{var_21 <- `var_21*`}, var_20) + -- if (|`var_19*`| = |`import*`|) + -- (fun_free_import: `%%`(import, var_19))*{var_19 <- `var_19*`, import <- `import*`} + -- fun_free_list: `%%`(var_19*{var_19 <- `var_19*`}, var_18) + -- if ((`var_17?` = ?()) <=> (`start?` = ?())) + -- (fun_free_start: `%%`(start, var_17))?{var_17 <- `var_17?`, start <- `start?`} + -- fun_free_opt: `%%`(var_17?{var_17 <- `var_17?`}, var_16) + -- if (|`var_15*`| = |`elem*`|) + -- (fun_free_elem: `%%`(elem, var_15))*{var_15 <- `var_15*`, elem <- `elem*`} + -- fun_free_list: `%%`(var_15*{var_15 <- `var_15*`}, var_14) + -- if (|`var_13*`| = |`data*`|) + -- (fun_free_data: `%%`(data, var_13))*{var_13 <- `var_13*`, data <- `data*`} + -- fun_free_list: `%%`(var_13*{var_13 <- `var_13*`}, var_12) + -- if (|`var_11*`| = |`func*`|) + -- (fun_free_func: `%%`(func, var_11))*{var_11 <- `var_11*`, func <- `func*`} + -- fun_free_list: `%%`(var_11*{var_11 <- `var_11*`}, var_10) + -- if (|`var_9*`| = |`table*`|) + -- (fun_free_table: `%%`(table, var_9))*{var_9 <- `var_9*`, table <- `table*`} + -- fun_free_list: `%%`(var_9*{var_9 <- `var_9*`}, var_8) + -- if (|`var_7*`| = |`mem*`|) + -- (fun_free_mem: `%%`(mem, var_7))*{var_7 <- `var_7*`, mem <- `mem*`} + -- fun_free_list: `%%`(var_7*{var_7 <- `var_7*`}, var_6) + -- if (|`var_5*`| = |`global*`|) + -- (fun_free_global: `%%`(global, var_5))*{var_5 <- `var_5*`, global <- `global*`} + -- fun_free_list: `%%`(var_5*{var_5 <- `var_5*`}, var_4) + -- if (|`var_3*`| = |`tag*`|) + -- (fun_free_tag: `%%`(tag, var_3))*{var_3 <- `var_3*`, tag <- `tag*`} + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- if (|`var_1*`| = |`type*`|) + -- (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 -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) + -- if (|`var_1*`| = |`func*`|) + -- (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 = @@ -4903,60 +6536,97 @@ 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: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'*` : deftype*}(dt*{dt <- `dt*`} ++ [dt_n]) = dt'*{dt' <- `dt'*`} ++ [$subst_all_deftype(dt_n, (dt' : deftype <: typeuse)*{dt' <- `dt'*`})] - -- if (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, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: + `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- fun_clos_deftypes: `%%`(dt#3*{dt#3 <- `dt*`}, var_1) + -- fun_subst_all_deftype: `%%%`(dt_n, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + -- if (dt'#1*{dt'#1 <- `dt'*`} = var_1) } ;; ../../../../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 - def $clos_valtype{C : context, t : valtype, `dt*` : deftype*}(C, t) = $subst_all_valtype(t, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- if (dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_valtype_case_0{C : context, t : valtype, `dt*` : deftype*, var_1 : deftype*, var_0 : valtype}: + `%%%`(C, t, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_valtype: `%%%`(t, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#4*{dt#4 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_deftype(context : context, deftype : deftype) : deftype +relation fun_clos_deftype: `%%%`(context, deftype, deftype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_deftype{C : context, dt : deftype, `dt'*` : deftype*}(C, dt) = $subst_all_deftype(dt, (dt' : deftype <: typeuse)*{dt' <- `dt'*`}) - -- if (dt'*{dt' <- `dt'*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_deftype_case_0{C : context, dt : deftype, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: + `%%%`(C, dt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_deftype: `%%%`(dt, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + -- if (dt'#2*{dt'#2 <- `dt'*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_tagtype(context : context, tagtype : tagtype) : tagtype +relation fun_clos_tagtype: `%%%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_tagtype{C : context, jt : typeuse, `dt*` : deftype*}(C, jt) = $subst_all_tagtype(jt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- if (dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_tagtype_case_0{C : context, jt : typeuse, `dt*` : deftype*, var_1 : deftype*, var_0 : tagtype}: + `%%%`(C, jt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_tagtype: `%%%`(jt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#5*{dt#5 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_externtype(context : context, externtype : externtype) : externtype +relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_externtype{C : context, xt : externtype, `dt*` : deftype*}(C, xt) = $subst_all_externtype(xt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- if (dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_externtype_case_0{C : context, xt : externtype, `dt*` : deftype*, var_1 : deftype*, var_0 : externtype}: + `%%%`(C, xt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_externtype: `%%%`(xt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#6*{dt#6 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_moduletype(context : context, moduletype : moduletype) : moduletype +relation fun_clos_moduletype: `%%%`(context, moduletype, moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_moduletype{C : context, mmt : moduletype, `dt*` : deftype*}(C, mmt) = $subst_all_moduletype(mmt, (dt : deftype <: typeuse)*{dt <- `dt*`}) - -- if (dt*{dt <- `dt*`} = $clos_deftypes(C.TYPES_context)) + rule fun_clos_moduletype_case_0{C : context, mmt : moduletype, `dt*` : deftype*, var_1 : deftype*, var_0 : moduletype}: + `%%%`(C, mmt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_moduletype: `%%%`(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#7*{dt#7 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -5000,10 +6670,11 @@ 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) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, 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)) + -- fun_unrolldt: `%%`(deftype, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Vectype_sub: `%|-%<:%`(context, vectype, vectype) @@ -5020,13 +6691,22 @@ 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) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) + -- 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, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] + 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 rec { @@ -5035,12 +6715,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)) -- wf_context: `%`(C) -- wf_typeuse: `%`(typeuse) -- Typeuse_ok: `%|-%:OK`(C, typeuse) @@ -5064,19 +6744,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)) -- wf_context: `%`(C) -- Numtype_ok: `%|-%:OK`(C, numtype) ;; ../../../../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)) -- wf_context: `%`(C) -- Vectype_ok: `%|-%:OK`(C, vectype) ;; ../../../../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)) -- wf_context: `%`(C) -- wf_reftype: `%`(reftype) -- Reftype_ok: `%|-%:OK`(C, reftype) @@ -5108,7 +6788,7 @@ relation Typeuse_ok: `%|-%:OK`(context, typeuse) ;; ../../../../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)) -- wf_context: `%`(C) -- Deftype_ok: `%|-%:OK`(C, deftype) @@ -5134,14 +6814,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)) -- wf_context: `%`(C) -- wf_valtype: `%`(valtype) -- Valtype_ok: `%|-%:OK`(C, 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)) -- wf_context: `%`(C) -- Packtype_ok: `%|-%:OK`(C, packtype) @@ -5172,7 +6852,7 @@ 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)) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) @@ -5181,10 +6861,13 @@ 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 ($unrollht_(C, (typeuse : typeuse <: heaptype)) = SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, typeuse <- `typeuse*`, `typeuse'*` <- `typeuse'**`} + -- if (|`var_0*`| = |`comptype'*`|) + -- if (|`var_0*`| = |`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'*`} + -- if (|`var_0*`| = |`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) @@ -5244,19 +6927,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) -- wf_context: `%`(C) - -- if ($clos_deftype(C, deftype_1) = $clos_deftype(C, deftype_2)) + -- if (var_0 = var_1) + -- 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) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) - -- 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)) -- if (i < |typeuse*{typeuse <- `typeuse*`}|) - -- Heaptype_sub: `%|-%<:%`(C, (typeuse*{typeuse <- `typeuse*`}[i] : typeuse <: heaptype), (deftype_2 : deftype <: heaptype)) + -- Heaptype_sub: `%|-%<:%`(C, $heaptype_typeuse(typeuse*{typeuse <- `typeuse*`}[i]), $heaptype_deftype(deftype_2)) + -- 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) @@ -5307,7 +6993,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) -- wf_context: `%`(C) -- wf_heaptype: `%`(STRUCT_heaptype) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) @@ -5315,7 +7001,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) -- wf_context: `%`(C) -- wf_heaptype: `%`(ARRAY_heaptype) -- wf_comptype: `%`(ARRAY_comptype(fieldtype)) @@ -5323,7 +7009,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) -- 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*`}))) @@ -5331,7 +7017,7 @@ 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)) -- wf_context: `%`(C) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) @@ -5342,7 +7028,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_heaptype: `%`(heaptype) -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) - -- Heaptype_sub: `%|-%<:%`(C, (C.TYPES_context[$proj_uN_0(typeidx).0] : deftype <: heaptype), heaptype) + -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0]), heaptype) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:61.1-63.53 rule `typeidx-r`{C : context, heaptype : heaptype, typeidx : typeidx}: @@ -5351,7 +7037,7 @@ relation Heaptype_sub: `%|-%<:%`(context, heaptype, heaptype) -- wf_heaptype: `%`(heaptype) -- wf_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)) + -- Heaptype_sub: `%|-%<:%`(C, heaptype, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0])) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:65.1-67.51 rule `rec-struct`{C : context, i : n, `final?` : final?, `fieldtype*` : fieldtype*}: @@ -5385,7 +7071,7 @@ 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 (j < |typeuse*{typeuse <- `typeuse*`}|) -- wf_context: `%`(C) -- wf_heaptype: `%`(REC_heaptype(i)) @@ -5466,19 +7152,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)) -- wf_context: `%`(C) -- Numtype_sub: `%|-%<:%`(C, numtype_1, numtype_2) ;; ../../../../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)) -- wf_context: `%`(C) -- Vectype_sub: `%|-%<:%`(C, vectype_1, vectype_2) ;; ../../../../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)) -- wf_context: `%`(C) -- wf_reftype: `%`(reftype_1) -- wf_reftype: `%`(reftype_2) @@ -5506,7 +7192,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)) -- wf_context: `%`(C) -- wf_valtype: `%`(valtype_1) -- wf_valtype: `%`(valtype_2) @@ -5514,7 +7200,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)) -- wf_context: `%`(C) -- Packtype_sub: `%|-%<:%`(C, packtype_1, packtype_2) @@ -5565,7 +7251,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) -- wf_context: `%`(C) -- wf_comptype: `%`(comptype) -- Expand: `%~~%`(deftype, comptype) @@ -5593,7 +7279,7 @@ 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)) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) @@ -5602,11 +7288,14 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} -- if (|x*{x <- `x*`}| <= 1) -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} - -- if (|`comptype'*`| = |`x*`|) - -- (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*`| = |`comptype'*`|) + -- if (|`var_0*`| = |`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'*`} + -- if (|`var_0*`| = |`x*`|) + -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- `x*`} + -- (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 { @@ -5668,7 +7357,7 @@ relation Memtype_ok: `%|-%:OK`(context, memtype) `%|-%:OK`(C, `%%PAGE`_memtype(addrtype, limits)) -- wf_context: `%`(C) -- wf_memtype: `%`(`%%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))) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Tabletype_ok: `%|-%:OK`(context, tabletype) @@ -5677,7 +7366,7 @@ relation Tabletype_ok: `%|-%:OK`(context, tabletype) `%|-%:OK`(C, `%%%`_tabletype(addrtype, limits, reftype)) -- wf_context: `%`(C) -- wf_tabletype: `%`(`%%%`_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) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec @@ -5759,7 +7448,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)) -- wf_context: `%`(C) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) -- Deftype_sub: `%|-%<:%`(C, deftype_2, deftype_1) @@ -5841,10 +7530,10 @@ 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))) -- 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))) -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec @@ -5870,28 +7559,30 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../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*}: + rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*, var_0 : deftype?}: `%|-%:OK`(C, CATCH_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`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 (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_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(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: + rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*, var_0 : deftype?}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`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 (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_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(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: @@ -5910,32 +7601,95 @@ relation Catch_ok: `%|-%:OK`(context, catch) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -def $default_(valtype : valtype) : val?? +relation fun_default__before_fun_default__case_7: `%`(valtype) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_6{ht : heaptype}: + `%`(REF_valtype(?(), ht)) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_5{ht : heaptype}: + `%`(REF_valtype(?(NULL_null), ht)) + -- wf_val: `%`(`REF.NULL_ADDR`_val) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_4: + `%`(V128_valtype) + -- wf_val: `%`(VCONST_val(V128_vectype, `%`_vec_(0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_3{var_0 : fN}: + `%`(F64_valtype) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_2{var_0 : fN}: + `%`(F32_valtype) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_1: + `%`(I64_valtype) + -- 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 + rule fun_default__case_0: + `%`(I32_valtype) + -- 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 +relation fun_default_: `%%`(valtype, val??) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_0: + `%%`(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_{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)))) + rule fun_default__case_1: + `%%`(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 + rule fun_default__case_2{var_0 : fN}: + `%%`(F32_valtype, ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_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)))))) + rule fun_default__case_3{var_0 : fN}: + `%%`(F64_valtype, ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + ;; ../../../../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))) + rule fun_default__case_4: + `%%`(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)) + rule fun_default__case_5{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 + rule fun_default__case_6{ht : heaptype}: + `%%`(REF_valtype(?(), ht), ?(?())) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_7{x0 : valtype}: + `%%`(x0, ?()) + -- ~ fun_default__before_fun_default__case_7: `%`(x0) ;; ../../../../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}: + rule _{t : valtype, var_0 : val??}: `|-%DEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) - -- if (!($default_(t)) =/= ?()) + -- if (var_0 =/= ?()) + -- if (!(var_0) =/= ?()) + -- fun_default_: `%%`(t, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -5944,12 +7698,14 @@ relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) `|-%:%->%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}, at, N) -- wf_memarg: `%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}) -- 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)))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -def $is_packtype(storagetype : storagetype) : bool +relation fun_is_packtype: `%%`(storagetype, bool) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - def $is_packtype{zt : storagetype}(zt) = (zt =/= ($unpack(zt) : valtype <: storagetype)) + rule fun_is_packtype_case_0{zt : storagetype, var_0 : valtype}: + `%%`(zt, (zt =/= $storagetype_valtype(var_0))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rec { @@ -5996,7 +7752,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_instrtype: `%`(`%->_%%`_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))) ;; ../../../../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*}: @@ -6086,32 +7842,34 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(NULL_null), ht)])) ;; ../../../../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)]))) + rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype, var_0 : 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(var_0)]))) -- 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(var_0)]))) -- 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)])) + -- 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) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt) + -- fun_diffrt: `%%%`(rt_1, rt_2, var_0) ;; ../../../../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)]))) + rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, `t*` : valtype*, rt : reftype, var_0 : 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)]))) -- 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)]))) + -- wf_instrtype: `%`(`%->_%%`_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*`} ++ [(rt : reftype <: valtype)])) + -- 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) -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) - -- Reftype_sub: `%|-%<:%`(C, $diffrt(rt_1, rt_2), rt) + -- Reftype_sub: `%|-%<:%`(C, var_0, rt) + -- fun_diffrt: `%%%`(rt_1, rt_2, var_0) ;; ../../../../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*}: @@ -6135,10 +7893,10 @@ 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*`}))) + `%|-%:%`(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*`}))) -- 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*`}))) @@ -6190,11 +7948,11 @@ 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*`}))) + `%|-%:%`(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*`}))) -- 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*`}))) @@ -6209,17 +7967,18 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*}: + rule throw{C : context, x : idx, `t_1*` : valtype*, `t*` : valtype*, `t_2*` : valtype*, var_0 : deftype?}: `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_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*`}))) - -- 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 (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_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*`}))) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:171.1-173.42 rule throw_ref{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: @@ -6252,10 +8011,10 @@ 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))]))) + `%|-%:%`(C, `REF.FUNC`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), $heaptype_deftype(dt))]))) -- 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))]))) -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) -- if (|C.REFS_context| > 0) @@ -6293,20 +8052,20 @@ 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]))) -- 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]))) -- Reftype_ok: `%|-%:OK`(C, rt) -- Reftype_ok: `%|-%:OK`(C, rt') -- Reftype_sub: `%|-%<:%`(C, rt, rt') ;; ../../../../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)]))) -- 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)]))) -- Reftype_ok: `%|-%:OK`(C, rt) -- Reftype_ok: `%|-%:OK`(C, rt') -- Reftype_sub: `%|-%<:%`(C, rt, rt') @@ -6319,17 +8078,19 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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))]))) + rule `struct.new`{C : context, x : idx, `zt*` : storagetype*, `mut?*` : mut?*, `var_0*` : valtype*}: + `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- `zt*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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 (|`var_0*`| = |`zt*`|) + -- (fun_unpack: `%%`(zt, var_0))*{var_0 <- `var_0*`, 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*}: + rule `struct.new_default`{C : context, x : idx, `mut?*` : mut?*, `zt*` : storagetype*, `var_0*` : valtype*}: `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) @@ -6337,47 +8098,53 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- 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*`} + -- (Defaultable: `|-%DEFAULTABLE`(var_0))*{var_0 <- `var_0*`} + -- if (|`var_0*`| = |`zt*`|) + -- (fun_unpack: `%%`(zt, var_0))*{var_0 <- `var_0*`, 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)]))) + rule `struct.get`{C : context, `sx?` : sx?, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, `mut?` : mut?, var_1 : bool, var_0 : valtype}: + `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([var_0]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([var_0]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, 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)) + -- if ((sx?{sx <- `sx?`} =/= ?()) <=> var_1) + -- fun_is_packtype: `%%`(zt, var_1) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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([]))) + rule `struct.set`{C : context, x : idx, i : fieldidx, zt : storagetype, `ft*` : fieldtype*, var_0 : valtype}: + `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) var_0]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) var_0]), [], `%`_resulttype([]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), 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), zt)) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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))]))) + rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([var_0 I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([var_0 I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: + rule `array.new_default`{C : context, x : idx, `mut?` : mut?, zt : storagetype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) @@ -6385,17 +8152,19 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) - -- Defaultable: `|-%DEFAULTABLE`($unpack(zt)) + -- Defaultable: `|-%DEFAULTABLE`(var_0) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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))]))) + rule `array.new_fixed`{C : context, x : idx, n : n, zt : storagetype, `mut?` : mut?, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype(var_0^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(var_0^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: @@ -6403,14 +8172,14 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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)))) -- 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)))) + -- 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) ;; ../../../../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}: + rule `array.new_data`{C : context, x : idx, y : idx, `mut?` : mut?, zt : storagetype, numtype : numtype, vectype : vectype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) @@ -6418,30 +8187,34 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) - -- if (($unpack(zt) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) + -- if ((var_0 = $valtype_numtype(numtype)) \/ (var_0 = $valtype_vectype(vectype))) -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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)]))) + rule `array.get`{C : context, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?, var_1 : bool, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([var_0]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([var_0]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) - -- if ((sx?{sx <- `sx?`} =/= ?()) <=> $is_packtype(zt)) + -- if ((sx?{sx <- `sx?`} =/= ?()) <=> var_1) + -- fun_is_packtype: `%%`(zt, var_1) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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([]))) + rule `array.set`{C : context, x : idx, zt : storagetype, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:305.1-306.43 rule `array.len`{C : context}: @@ -6451,14 +8224,15 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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([]))) + rule `array.fill`{C : context, x : idx, zt : storagetype, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0 I32_valtype]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0 I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: @@ -6484,10 +8258,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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) + -- Storagetype_sub: `%|-%<:%`(C, $storagetype_reftype(C.ELEMS_context[$proj_uN_0(y).0]), 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}: + rule `array.init_data`{C : context, x : idx, y : idx, zt : storagetype, numtype : numtype, vectype : vectype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) @@ -6495,9 +8269,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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) = (numtype : numtype <: valtype)) \/ ($unpack(zt) = (vectype : vectype <: valtype))) + -- if ((var_0 = $valtype_numtype(numtype)) \/ (var_0 = $valtype_vectype(vectype))) -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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?}: @@ -6567,60 +8342,60 @@ 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)]))) + `%|-%:%`(C, `TABLE.GET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_reftype(rt)]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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([]))) + `%|-%:%`(C, `TABLE.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt)]), [], `%`_resulttype([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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)]))) + `%|-%:%`(C, `TABLE.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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)]))) + `%|-%:%`(C, `TABLE.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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([]))) + `%|-%:%`(C, `TABLE.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_reftype(rt) $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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([]))) + `%|-%:%`(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([]))) -- 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)) -- if ($proj_uN_0(x_1).0 < |C.TABLES_context|) @@ -6631,11 +8406,11 @@ 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([]))) + `%|-%:%`(C, `TABLE.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.TABLES_context|) -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_tabletype(at, lim, rt_1)) @@ -6655,40 +8430,40 @@ 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)]))) + `%|-%:%`(C, `MEMORY.SIZE`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%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)]))) + `%|-%:%`(C, `MEMORY.GROW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%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([]))) + `%|-%:%`(C, `MEMORY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%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([]))) + `%|-%:%`(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([]))) -- 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)) -- if ($proj_uN_0(x_1).0 < |C.MEMS_context|) @@ -6698,10 +8473,10 @@ 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([]))) + `%|-%:%`(C, `MEMORY.INIT`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6719,10 +8494,10 @@ 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)]))) + `%|-%:%`(C, LOAD_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6730,10 +8505,10 @@ 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)]))) + `%|-%:%`(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)]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6741,10 +8516,10 @@ 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([]))) + `%|-%:%`(C, STORE_instr(nt, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6752,10 +8527,10 @@ 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([]))) + `%|-%:%`(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([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6763,10 +8538,10 @@ 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]))) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6774,10 +8549,10 @@ 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]))) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6785,10 +8560,10 @@ 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]))) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6796,10 +8571,10 @@ 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]))) + `%|-%:%`(C, VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6807,10 +8582,10 @@ 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]))) + `%|-%:%`(C, VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6819,10 +8594,10 @@ 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([]))) + `%|-%:%`(C, VSTORE_instr(V128_vectype, x, memarg), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6830,10 +8605,10 @@ 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([]))) + `%|-%:%`(C, VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i), `%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) -- 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)) -- if ($proj_uN_0(x).0 < |C.MEMS_context|) -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%PAGE`_memtype(at, lim)) @@ -6842,45 +8617,45 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) ;; ../../../../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_}: @@ -6974,35 +8749,38 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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*}: + rule vshuffle{C : context, sh : bshape, `i*` : laneidx*, var_0 : dim}: `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) -- wf_instrtype: `%`(`%->_%%`_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*`} + -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0(var_0).0)))*{i <- `i*`} + -- fun_dim: `%%`($proj_bshape_0(sh).0, var_0) ;; ../../../../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)]))) + rule vextract_lane{C : context, sh : shape, `sx?` : sx?, i : laneidx, var_0 : dim}: + `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) -- wf_context: `%`(C) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([($unpackshape(sh) : numtype <: valtype)]))) - -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) + -- if ($proj_uN_0(i).0 < $proj_dim_0(var_0).0) + -- fun_dim: `%%`(sh, var_0) ;; ../../../../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]))) + rule vreplace_lane{C : context, sh : shape, i : laneidx, var_0 : dim}: + `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype ($unpackshape(sh) : numtype <: valtype)]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(i).0 < $proj_dim_0($dim(sh)).0) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) + -- if ($proj_uN_0(i).0 < $proj_dim_0(var_0).0) + -- fun_dim: `%%`(sh, var_0) ;; ../../../../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__}: @@ -7048,7 +8826,7 @@ 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*`}))) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) @@ -7063,8 +8841,9 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- 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*`}))) + -- if (var_0 =/= ?()) + -- 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*`}))) + -- 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}: @@ -7101,11 +8880,12 @@ relation Expr_ok: `%|-%:%`(context, expr, resulttype) ;; ../../../../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}: + rule _{t : valtype, var_0 : val??}: `|-%NONDEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) - -- if (!($default_(t)) = ?()) + -- if (var_0 =/= ?()) + -- if (!(var_0) = ?()) + -- fun_default_: `%%`(t, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7192,12 +8972,12 @@ 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)) + `%|-%CONST`(C, BINOP_instr($numtype_addrtype(Inn), binop)) -- 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)) -- 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) @@ -7226,23 +9006,25 @@ 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*`}) -- 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)) -- 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)) + -- 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) -- wf_context: `%`(C) -- wf_tag: `%`(TAG_tag(tagtype)) -- Tagtype_ok: `%|-%:OK`(C, tagtype) + -- fun_clos_tagtype: `%%%`(C, tagtype, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Global_ok: `%|-%:%`(context, global, globaltype) @@ -7275,7 +9057,7 @@ relation Table_ok: `%|-%:%`(context, table, tabletype) -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) -- 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)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Local_ok: `%|-%:%`(context, local, localtype) @@ -7326,7 +9108,7 @@ relation Datamode_ok: `%|-%:%`(context, datamode, datatype) -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) -- 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)) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Data_ok: `%|-%:%`(context, data, datatype) @@ -7363,7 +9145,7 @@ relation Elemmode_ok: `%|-%:%`(context, elemmode, elemtype) -- 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)) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_addrtype(at)) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Elem_ok: `%|-%:%`(context, elem, elemtype) @@ -7373,7 +9155,7 @@ relation Elem_ok: `%|-%:%`(context, elem, elemtype) -- wf_context: `%`(C) -- wf_elem: `%`(ELEM_elem(elemtype, expr*{expr <- `expr*`}, elemmode)) -- 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) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec @@ -7390,11 +9172,12 @@ 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) -- wf_context: `%`(C) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) -- Externtype_ok: `%|-%:OK`(C, xt) + -- fun_clos_externtype: `%%%`(C, xt, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Externidx_ok: `%|-%:%`(context, externidx, externtype) @@ -7436,10 +9219,10 @@ 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))) + `%|-%:%`(C, FUNC_externidx(x), FUNC_externtype($typeuse_deftype(dt))) -- wf_context: `%`(C) -- wf_externidx: `%`(FUNC_externidx(x)) - -- wf_externtype: `%`(FUNC_externtype((dt : deftype <: typeuse))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(dt))) -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) @@ -7511,16 +9294,18 @@ 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) + -- 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) ;; ../../../../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_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) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- `nm*`} @@ -7554,12 +9339,14 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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 (x*{x <- `x*`} = var_1) -- 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*`})) + -- 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 = @@ -7682,40 +9469,127 @@ def $inv_zbytes_(storagetype : storagetype, byte*) : lit_ def $inv_cbytes_(Cnn : Cnn, byte*) : lit_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $signed_(N : N, nat : nat) : int +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?? +relation fun_sx_before_fun_sx_case_7: `%`(storagetype) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $sx{consttype : consttype}((consttype : consttype <: storagetype)) = ?(?()) + rule fun_sx_case_6: + `%`(I16_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 + rule fun_sx_case_5: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_4: + `%`(V128_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_sx: `%%`(storagetype, sx??) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_0: + `%%`(I32_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_1: + `%%`(I64_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_2: + `%%`(F32_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_3: + `%%`(F64_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_4: + `%%`(V128_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_5: + `%%`(I8_storagetype, ?(?(S_sx))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_6: + `%%`(I16_storagetype, ?(?(S_sx))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_7{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_sx_before_fun_sx_case_7: `%`(x0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $zero(lanetype : lanetype) : lane_ +relation fun_zero: `%%`(lanetype, lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_zero_case_0: + `%%`(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 + rule fun_zero_case_1: + `%%`(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 + rule fun_zero_case_2: + `%%`(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 + rule fun_zero_case_3: + `%%`(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{Jnn : Jnn}((Jnn : Jnn <: lanetype)) = mk_lane__2_lane_(Jnn, `%`_uN(0)) - -- wf_lane_: `%%`((Jnn : Jnn <: lanetype), mk_lane__2_lane_(Jnn, `%`_uN(0))) + rule fun_zero_case_4{var_0 : fN}: + `%%`(F32_lanetype, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_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)))))) + rule fun_zero_case_5{var_0 : fN}: + `%%`(F64_lanetype, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -7749,7 +9623,8 @@ def $ineg_(N : N, iN : iN) : iN ;; ../../../../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 @@ -7761,13 +9636,18 @@ 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))) + rule fun_iextend__case_0{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)))))) + 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) + -- wf_uN: `%%`(N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN @@ -7788,34 +9668,58 @@ def $imul_(N : N, iN : iN, iN : iN) : iN -- 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))) + 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)))) -- 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)) = ?() + 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, ?()) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) + -- if (((var_0 : int <:> rat) / (var_1 : 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)))))) + 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) + -- wf_uN: `%%`(N, `%`_uN(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))) + 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)))) -- 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)) = ?() + 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)))))))) - -- wf_uN: `%%`(N, `%`_uN($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))) + 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))) + -- 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) + -- wf_uN: `%%`(N, `%`_uN(var_0)) + -- if ((j_1 = var_1) /\ (j_2 = var_2)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -7826,7 +9730,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 @@ -7837,7 +9743,9 @@ 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 @@ -7845,8 +9753,11 @@ def $iadd_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN 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) + -- wf_uN: `%%`(N, `%`_uN(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 @@ -7854,8 +9765,11 @@ def $isub_sat_(N : N, sx : sx, iN : iN, iN : iN) : iN 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) + -- wf_uN: `%%`(N, `%`_uN(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 @@ -7903,15 +9817,17 @@ def $ibitselect_(N : N, iN : iN, iN : iN, iN : iN) : iN 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 +relation fun_ieqz_: `%%%`(N, 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))) + rule fun_ieqz__case_0{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 +relation fun_inez_: `%%%`(N, 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))) + rule fun_inez__case_0{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 @@ -7932,8 +9848,10 @@ def $ilt_(N : N, sx : sx, iN : iN, iN : iN) : u32 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))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -7941,8 +9859,10 @@ def $igt_(N : N, sx : sx, iN : iN, iN : iN) : u32 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))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -7950,8 +9870,10 @@ def $ile_(N : N, sx : sx, iN : iN, iN : iN) : u32 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))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -7959,8 +9881,10 @@ def $ige_(N : N, sx : sx, iN : iN, iN : iN) : u32 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))) + -- wf_uN: `%%`(32, `%`_uN($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* @@ -8071,1182 +9995,5515 @@ 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_ +relation fun_lpacknum_: `%%%`(lanetype, 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)) + rule fun_lpacknum__case_0{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_{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 fun_lpacknum__case_1{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 $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 + rule fun_lpacknum__case_2{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 $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 fun_lpacknum__case_3{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 $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 + rule fun_lpacknum__case_4{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 $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))) + rule fun_lpacknum__case_5{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 -def $cunpacknum_(storagetype : storagetype, lit_ : lit_) : lit_ +relation fun_cpacknum_: `%%%`(storagetype, lit_, lit_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{consttype : consttype, c : lit_}((consttype : consttype <: storagetype), c) = c + rule fun_cpacknum__case_0{c : lit_}: + `%%%`(I32_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 fun_cpacknum__case_1{c : lit_}: + `%%%`(I64_storagetype, c, 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))) + rule fun_cpacknum__case_2{c : lit_}: + `%%%`(F32_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))) + rule fun_cpacknum__case_3{c : lit_}: + `%%%`(F64_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))) + rule fun_cpacknum__case_4{c : lit_}: + `%%%`(V128_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))) + rule fun_cpacknum__case_5{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 $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_cpacknum__case_6{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 fun_lunpacknum_: `%%%`(lanetype, lane_, num_) ;; ../../../../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_lunpacknum__case_0{c : num_}: + `%%%`(I32_lanetype, mk_lane__0_lane_(I32_numtype, 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, 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_lunpacknum__case_1{c : num_}: + `%%%`(I64_lanetype, mk_lane__0_lane_(I64_numtype, 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, 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_lunpacknum__case_2{c : num_}: + `%%%`(F32_lanetype, mk_lane__0_lane_(F32_numtype, 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, 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_lunpacknum__case_3{c : num_}: + `%%%`(F64_lanetype, mk_lane__0_lane_(F64_numtype, 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, 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_lunpacknum__case_4{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 $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_lunpacknum__case_5{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 -def $binop_(numtype : numtype, binop_ : binop_, num_ : num_, num_ : num_) : num_* +relation fun_cunpacknum_: `%%%`(storagetype, lit_, lit_) ;; ../../../../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_cunpacknum__case_0{c : lit_}: + `%%%`(I32_storagetype, c, c) + ;; ../../../../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_cunpacknum__case_1{c : lit_}: + `%%%`(I64_storagetype, c, c) + ;; ../../../../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_cunpacknum__case_2{c : lit_}: + `%%%`(F32_storagetype, c, c) + ;; ../../../../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_cunpacknum__case_3{c : lit_}: + `%%%`(F64_storagetype, c, c) + ;; ../../../../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_cunpacknum__case_4{c : lit_}: + `%%%`(V128_storagetype, c, c) + ;; ../../../../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_cunpacknum__case_5{c : uN, var_0 : consttype?}: + `%%%`(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)))) + -- fun_cunpack: `%%`($storagetype_packtype(I8_packtype), var_0) + -- if (var_0 =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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 $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_cunpacknum__case_6{c : uN, var_0 : consttype?}: + `%%%`(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)))) + -- fun_cunpack: `%%`($storagetype_packtype(I16_packtype), var_0) + -- if (var_0 =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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 fun_unop_: `%%%%`(numtype, unop_, 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, 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_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))]) + -- 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 $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_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))]) + -- 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 $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_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))]) + -- 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 $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_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))]) + -- 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 $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_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))]) + -- 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 $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_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))]) + -- 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 $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_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) + -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, var_0)) + ;; ../../../../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_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) + -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, var_0)) + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} -;; ../../../../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) + 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#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)} -;; ../../../../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) + 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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + ;; ../../../../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_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#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)} + +;; ../../../../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 - 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_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))]) + -- 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 $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_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))]) + -- 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 $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_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))]) + -- 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 $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_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))]) + -- 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 $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_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))]) + -- 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 $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_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))]) + -- 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 $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_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#30)*{iter_0#30 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- lift(var_0)} + ;; ../../../../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_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#32)*{iter_0#32 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- lift(var_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_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#34)*{iter_0#34 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- lift(var_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_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#36)*{iter_0#36 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- lift(var_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))] - -- wf_num_: `%%`((Inn_1 : addrtype <: numtype), mk_num__0_num_(Inn_1, i_1)) - -- if ($size((Inn_1 : addrtype <: numtype)) = $size((Fnn_2 : Fnn <: numtype))) + 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))]) + -- 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 $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))] - -- wf_num_: `%%`((Fnn_1 : Fnn <: numtype), mk_num__1_num_(Fnn_1, f_1)) - -- if ($size((Fnn_1 : Fnn <: numtype)) = $size((Inn_2 : addrtype <: numtype))) + 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))]) + -- 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.2-numerics.vector.spectec -def $lanes_(shape : shape, vec_ : vec_) : lane_* + ;; ../../../../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))]) + -- 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.2-numerics.vector.spectec -def $inv_lanes_(shape : shape, lane_*) : vec_ + ;; ../../../../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))]) + -- 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.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_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))]) + -- 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.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_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))]) + -- 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.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.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)))]) + -- 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.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 ($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.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)))]) + -- 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.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.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)))]) + -- 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.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, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)))*{c_1 <- `c_1*`}) + ;; ../../../../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)))]) + -- 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.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, `c**` : lane_**, `c_1*` : lane_*}(`%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**`} - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), c))*{c <- `c*`}*{`c*` <- `c**`} - -- 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1)) - -- if (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*`})) + ;; ../../../../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))]) + -- 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.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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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*`})] - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2)) - -- if (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*`}) + ;; ../../../../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))]) + -- 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.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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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*`})] - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2)) - -- if (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*`}) + ;; ../../../../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))]) + -- 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.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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%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**`} - -- (wf_lane_: `%%`((Jnn : Jnn <: lanetype), c))*{c <- `c*`}*{`c*` <- `c**`} - -- 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2)) - -- if (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*`})) + ;; ../../../../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))]) + -- 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.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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%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**`} - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), c))*{c <- `c*`}*{`c*` <- `c**`} - -- 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2)) - -- if (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*`})) + ;; ../../../../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#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)} -;; ../../../../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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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**`} - -- (wf_lane_: `%%`((Jnn : Jnn <: lanetype), c))*{c <- `c*`}*{`c*` <- `c**`} - -- 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2)) - -- if (c_3*{c_3 <- `c_3*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_3)) - -- if (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*`})) + ;; ../../../../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#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)} -;; ../../../../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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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**`} - -- (wf_lane_: `%%`((Fnn : Fnn <: lanetype), c))*{c <- `c*`}*{`c*` <- `c**`} - -- 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2)) - -- if (c_3*{c_3 <- `c_3*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_3)) - -- if (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*`})) + ;; ../../../../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#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)} -;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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*`}) - -- 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2)) - -- if (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*`}) + ;; ../../../../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#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)} -;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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*`}) - -- 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2)) - -- if (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*`}) + ;; ../../../../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#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)} -;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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*`}) - -- 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Fnn : Fnn <: lanetype), `%`_dim(M)), v_2)) - -- if (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)) + ;; ../../../../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#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)} -;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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*`}) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`}) + ;; ../../../../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#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)} -;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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*`}) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c*{c <- `c*`} = $f_($lsizenn((Jnn : Jnn <: lanetype)), sx, !($proj_lane__2(c_1)), i)*{c_1 <- `c_1*`}) + ;; ../../../../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#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)} -;; ../../../../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, `c_1*` : lane_*}(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1) = $irev_(32, c) - -- 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)) - -- if (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){}) + ;; ../../../../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#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)} -;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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*`}) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2)) - -- if (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*`}) + ;; ../../../../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#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)} -;; ../../../../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, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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*`}) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), c))*{c <- `c*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))), c_2))*{c_2 <- `c_2*`} - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M))) - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), v_2)) - -- if (c*{c <- `c*`} = c_1*{c_1 <- `c_1*`} ++ c_2*{c_2 <- `c_2*`}[$proj_uN_0(i).0]*{i <- `i*`}) + ;; ../../../../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#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)} -;; ../../../../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.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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_testop_: `%%%%`(numtype, testop_, num_, u32) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_testop__case_0{i : uN, var_0 : u32}: + `%%%%`(I32_numtype, mk_testop__0_testop_(I32_Inn, EQZ_testop_Inn), mk_num__0_num_(I32_Inn, i), var_0) + -- fun_ieqz_: `%%%`($sizenn($numtype_addrtype(I32_Inn)), i, var_0) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_testop__case_1{i : uN, var_0 : u32}: + `%%%%`(I64_numtype, mk_testop__0_testop_(I64_Inn, EQZ_testop_Inn), mk_num__0_num_(I64_Inn, i), var_0) + -- fun_ieqz_: `%%%`($sizenn($numtype_addrtype(I64_Inn)), i, var_0) + +;; ../../../../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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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))]) + -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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))]) + -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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))]) + -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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))]) + -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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))]) + -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), 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))]) + -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), 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))]) + -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), 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))]) + -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) + -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $vvbinop_(vectype : vectype, vvbinop : vvbinop, vec_ : vec_, vec_ : vec_) : vec_* +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 +relation fun_zeroop: `%%%%`(shape, shape, vcvtop__, zero?) ;; ../../../../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_0{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)), ?()) + ;; ../../../../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_1{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)), ?()) + ;; ../../../../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_2{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)), ?()) + ;; ../../../../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_3{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)), ?()) -;; ../../../../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_4{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)), ?()) -;; ../../../../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_5{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)), ?()) + ;; ../../../../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_6{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)), ?()) + ;; ../../../../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_7{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)), ?()) + ;; ../../../../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_8{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)), ?()) + ;; ../../../../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_9{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)), ?()) + ;; ../../../../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_10{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)), ?()) + ;; ../../../../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_11{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)), ?()) + ;; ../../../../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_12{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)), ?()) + ;; ../../../../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_13{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)), ?()) + ;; ../../../../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_14{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)), ?()) -;; ../../../../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))) + rule fun_zeroop_case_15{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)), ?()) + ;; ../../../../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_zeroop_case_16{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#2833?{half#2833 <- `half?`}, sx)), ?()) + ;; ../../../../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_zeroop_case_17{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#2834?{half#2834 <- `half?`}, sx)), ?()) + ;; ../../../../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_zeroop_case_18{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#2835?{half#2835 <- `half?`}, sx)), ?()) + ;; ../../../../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_zeroop_case_19{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#2836?{half#2836 <- `half?`}, sx)), ?()) + ;; ../../../../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_zeroop_case_20{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#2837?{half#2837 <- `half?`}, sx)), ?()) + ;; ../../../../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_zeroop_case_21{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#2838?{half#2838 <- `half?`}, sx)), ?()) + ;; ../../../../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_zeroop_case_22{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#2839?{half#2839 <- `half?`}, sx)), ?()) + ;; ../../../../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_zeroop_case_23{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#2840?{half#2840 <- `half?`}, sx)), ?()) + ;; ../../../../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_zeroop_case_24{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#3245?{zero#3245 <- `zero?`})), zero#3246?{zero#3246 <- `zero?`}) + ;; ../../../../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_zeroop_case_25{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#3247?{zero#3247 <- `zero?`})), zero#3248?{zero#3248 <- `zero?`}) + ;; ../../../../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_zeroop_case_26{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#3249?{zero#3249 <- `zero?`})), zero#3250?{zero#3250 <- `zero?`}) + ;; ../../../../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_zeroop_case_27{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#3251?{zero#3251 <- `zero?`})), zero#3252?{zero#3252 <- `zero?`}) + ;; ../../../../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_zeroop_case_28{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#3253?{zero#3253 <- `zero?`})), zero#3254?{zero#3254 <- `zero?`}) + ;; ../../../../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_zeroop_case_29{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#3255?{zero#3255 <- `zero?`})), zero#3256?{zero#3256 <- `zero?`}) + ;; ../../../../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_zeroop_case_30{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#3257?{zero#3257 <- `zero?`})), zero#3258?{zero#3258 <- `zero?`}) + ;; ../../../../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_zeroop_case_31{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#3259?{zero#3259 <- `zero?`})), zero#3260?{zero#3260 <- `zero?`}) + ;; ../../../../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_zeroop_case_32{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#3261?{zero#3261 <- `zero?`})), zero#3262?{zero#3262 <- `zero?`}) + ;; ../../../../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_zeroop_case_33{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#3263?{zero#3263 <- `zero?`})), zero#3264?{zero#3264 <- `zero?`}) + ;; ../../../../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_zeroop_case_34{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#3265?{zero#3265 <- `zero?`})), zero#3266?{zero#3266 <- `zero?`}) -;; ../../../../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_zeroop_case_35{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#3267?{zero#3267 <- `zero?`})), zero#3268?{zero#3268 <- `zero?`}) + ;; ../../../../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_zeroop_case_36{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#3269?{zero#3269 <- `zero?`})), zero#3270?{zero#3270 <- `zero?`}) + ;; ../../../../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_zeroop_case_37{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#3271?{zero#3271 <- `zero?`})), zero#3272?{zero#3272 <- `zero?`}) -;; ../../../../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_zeroop_case_38{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#3273?{zero#3273 <- `zero?`})), zero#3274?{zero#3274 <- `zero?`}) + ;; ../../../../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_zeroop_case_39{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#3275?{zero#3275 <- `zero?`})), zero#3276?{zero#3276 <- `zero?`}) + ;; ../../../../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_zeroop_case_40{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)) + ;; ../../../../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_zeroop_case_41{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)) + ;; ../../../../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_zeroop_case_42{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)) + ;; ../../../../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_zeroop_case_43{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)) + ;; ../../../../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_zeroop_case_44{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), ?()) + ;; ../../../../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_zeroop_case_45{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), ?()) + ;; ../../../../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_zeroop_case_46{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), ?()) + ;; ../../../../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_zeroop_case_47{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), ?()) + +;; ../../../../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 - 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_0{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)) + ;; ../../../../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_1{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)) -;; ../../../../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, c : 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)] - -- wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2))), mk_lane__2_lane_(Jnn_2, c)) - -- if (c = $extend__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Jnn_2 : Jnn <: lanetype)), sx, c_1)) + rule fun_halfop_case_2{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)) + ;; ../../../../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, c : fN}(`%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))] - -- 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))) - -- if (c = $convert__($lsizenn1((Jnn_1 : Jnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), sx, c_1)) + rule fun_halfop_case_3{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)) + ;; ../../../../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, `c?` : iN?}(`%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?`}) - -- (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?`} - -- if (c?{c <- `c?`} = $trunc_sat__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1)) + rule fun_halfop_case_4{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)) + ;; ../../../../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, `c?` : iN?}(`%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?`}) - -- (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?`} - -- if (c?{c <- `c?`} = $relaxed_trunc__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Inn_2 : addrtype <: lanetype)), sx, c_1)) + rule fun_halfop_case_5{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)) + ;; ../../../../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, `c*` : 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*`} - -- (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*`} - -- if (c*{c <- `c*`} = $demote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1)) + rule fun_halfop_case_6{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)) + ;; ../../../../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, `c*` : 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*`} - -- (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*`} - -- if (c*{c <- `c*`} = $promote__($lsizenn1((Fnn_1 : Fnn <: lanetype)), $lsizenn2((Fnn_2 : Fnn <: lanetype)), c_1)) + rule fun_halfop_case_7{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)) -;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1) = v - -- wf_uN: `%%`(128, v) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`(Lnn_2, c))*{c <- `c*`}*{`c*` <- `c**`} - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) - -- 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) = ?())) - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1)) - -- if (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**`}) + rule fun_halfop_case_8{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)) + ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- wf_uN: `%%`(128, v) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`(Lnn_2, c))*{c <- `c*`}*{`c*` <- `c**`} - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(half)) - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2]) - -- if (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**`}) + rule fun_halfop_case_9{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)) + ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v - -- wf_uN: `%%`(128, v) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`(Lnn_2, c))*{c <- `c*`}*{`c*` <- `c**`} - -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) - -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)) - -- if (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**`}) + rule fun_halfop_case_10{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)) -;; ../../../../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_halfop_case_11{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)) + ;; ../../../../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_halfop_case_12{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)) -;; ../../../../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_halfop_case_13{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)) -;; ../../../../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))) + rule fun_halfop_case_14{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)) + ;; ../../../../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_halfop_case_15{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)) -;; ../../../../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_halfop_case_16{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#2841?{half#2841 <- `half?`}, sx)), half#2842?{half#2842 <- `half?`}) -;; ../../../../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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), `%X%`_shape((Jnn_2 : Jnn <: lanetype), `%`_dim(M_2)), sx, v_1, v_2) = v - -- wf_uN: `%%`(128, v) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), 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*`} - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1)) - -- if (c_2*{c_2 <- `c_2*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_2)) - -- if (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*`}) - -- if (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*`}) - -- if (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*`})) + rule fun_halfop_case_17{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#2843?{half#2843 <- `half?`}, sx)), half#2844?{half#2844 <- `half?`}) -;; ../../../../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*`} - -- (wf_uN: `%%`(N, `%`_uN(j_1)))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, `%`_uN(j_2)))*{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*`}) + rule fun_halfop_case_18{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#2845?{half#2845 <- `half?`}, sx)), half#2846?{half#2846 <- `half?`}) -;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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*`}) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), c_1))*{c_1 <- `c_1*`} - -- (wf_uN: `%%`($lsize((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))) - -- if (c_1*{c_1 <- `c_1*`} = $lanes_(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1)), v_1)) - -- if (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*`}) - -- if (c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`})) + rule fun_halfop_case_19{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#2847?{half#2847 <- `half?`}, sx)), half#2848?{half#2848 <- `half?`}) -;; ../../../../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_halfop_case_20{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#2849?{half#2849 <- `half?`}, sx)), half#2850?{half#2850 <- `half?`}) -;; ../../../../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*`} - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{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*`}) + rule fun_halfop_case_21{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#2851?{half#2851 <- `half?`}, sx)), half#2852?{half#2852 <- `half?`}) -;; ../../../../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*`} - -- (wf_uN: `%%`(N, j_1))*{j_1 <- `j_1*`} - -- (wf_uN: `%%`(N, j_2))*{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*`}) + rule fun_halfop_case_22{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#2853?{half#2853 <- `half?`}, sx)), half#2854?{half#2854 <- `half?`}) -;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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*`}) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), c_1))*{c_1 <- `c_1*`} - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn_1 : Jnn <: lanetype), `%`_dim(M_1))), c_2))*{c_2 <- `c_2*`} - -- (wf_uN: `%%`($lsize((Jnn_2 : Jnn <: lanetype)), c'_1))*{c'_1 <- `c'_1*`} - -- (wf_uN: `%%`($lsize((Jnn_2 : Jnn <: lanetype)), 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))) - -- if (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]) - -- if (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]) - -- if (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*`}) - -- if (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*`}) - -- if (c*{c <- `c*`} = $f_($lsizenn2((Jnn_2 : Jnn <: lanetype)), c'_1*{c'_1 <- `c'_1*`}, c'_2*{c'_2 <- `c'_2*`})) + rule fun_halfop_case_23{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#2855?{half#2855 <- `half?`}, sx)), half#2856?{half#2856 <- `half?`}) -;; ../../../../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_halfop_case_24{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#3277?{zero#3277 <- `zero?`})), ?()) -;; ../../../../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)) + rule fun_halfop_case_25{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#3278?{zero#3278 <- `zero?`})), ?()) + ;; ../../../../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)) + rule fun_halfop_case_26{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#3279?{zero#3279 <- `zero?`})), ?()) + ;; ../../../../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)) + rule fun_halfop_case_27{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#3280?{zero#3280 <- `zero?`})), ?()) -;; ../../../../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, M : nat, c' : uN, c'' : uN}(`%`_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 - -- wf_uN: `%%`(128, c) - -- wf_uN: `%%`(128, c') - -- 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)) - -- if ($jsizenn(Jnn) = (2 * $lsizenn1((Jnn_1 : Jnn <: lanetype)))) - -- if (M = (2 * M_2)) - -- if (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)) - -- if (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)) + rule fun_halfop_case_28{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#3281?{zero#3281 <- `zero?`})), ?()) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax num = - | CONST(numtype : numtype, num_) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_29{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#3282?{zero#3282 <- `zero?`})), ?()) -;; ../../../../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 + rule fun_halfop_case_30{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#3283?{zero#3283 <- `zero?`})), ?()) -;; ../../../../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_halfop_case_31{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#3284?{zero#3284 <- `zero?`})), ?()) -;; ../../../../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_halfop_case_32{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#3285?{zero#3285 <- `zero?`})), ?()) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax result = - | _VALS(`val*` : val*) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_33{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#3286?{zero#3286 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_34{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#3287?{zero#3287 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_35{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#3288?{zero#3288 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_36{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#3289?{zero#3289 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_37{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#3290?{zero#3290 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_38{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#3291?{zero#3291 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_39{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#3292?{zero#3292 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_40{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_41{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_42{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_43{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_44{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_45{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_46{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_47{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)) + +;; ../../../../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)) + -- 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, 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*`}|)]))) + -- wf_uN: `%%`(N, `%`_uN(0)) + -- 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, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#1))*{c_1#1 <- `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#3)))*{c#3 <- `c*`} + -- if (c_1#2*{c_1#2 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c#4*{c#4 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#3)))*{c_1#3 <- `c_1*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), 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#6)))*{c#6 <- `c*`} + -- if (c_1#5*{c_1#5 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c#7*{c#7 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#7))*{c_1#7 <- `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#9)))*{c#9 <- `c*`} + -- if (c_1#8*{c_1#8 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c#10*{c#10 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#9)))*{c_1#9 <- `c_1*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#10))*{c_1#10 <- `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#12)))*{c#12 <- `c*`} + -- if (c_1#11*{c_1#11 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c#13*{c#13 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#12)))*{c_1#12 <- `c_1*`}) + +;; ../../../../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, `c**` : lane_**, `c_1*` : lane_*}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#17*{c#17 <- `c*#3`})*{`c*#3` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), c#15))*{c#15 <- `c*#1`}*{`c*#1` <- `c**`} + -- 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#97))))*{iter_0#97 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`} + -- if (c_1#14*{c_1#14 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1)) + -- if (c#16*{c#16 <- `c*#2`}*{`c*#2` <- `c**`} = $setproduct_(syntax lane_, 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#15)))))}*{c_1#15 <- `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, `c**` : lane_**, `c_1*` : lane_*}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#20*{c#20 <- `c*#6`})*{`c*#6` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), c#18))*{c#18 <- `c*#4`}*{`c*#4` <- `c**`} + -- 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#99))))*{iter_0#99 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#16)))))}*{c_1#16 <- `c_1*`} + -- if (c_1#17*{c_1#17 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1)) + -- if (c#19*{c#19 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, 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#18)))))}*{c_1#18 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#23)*{c#23 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#19))*{c_1#19 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#1))*{c_2#1 <- `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#21)))*{c#21 <- `c*`} + -- if (c_1#20*{c_1#20 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#2*{c_2#2 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#22*{c#22 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#21)), !($proj_lane__2(c_2#3)))*{c_1#21 <- `c_1*`, c_2#3 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#26)*{c#26 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#22))*{c_1#22 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#4))*{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#24)))*{c#24 <- `c*`} + -- if (c_1#23*{c_1#23 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#5*{c_2#5 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#25*{c#25 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#6)))*{c_1#24 <- `c_1*`, c_2#6 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#29)*{c#29 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#25))*{c_1#25 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#7))*{c_2#7 <- `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#27)))*{c#27 <- `c*`} + -- if (c_1#26*{c_1#26 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#8*{c_2#8 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#28*{c#28 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#27)), !($proj_lane__2(c_2#9)))*{c_1#27 <- `c_1*`, c_2#9 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#32)*{c#32 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#28))*{c_1#28 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#10))*{c_2#10 <- `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#30)))*{c#30 <- `c*`} + -- if (c_1#29*{c_1#29 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#11*{c_2#11 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#31*{c#31 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#12)))*{c_1#30 <- `c_1*`, c_2#12 <- `c_2*`}) + +;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#35)*{c#35 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#31))*{c_1#31 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#13))*{c_2#13 <- `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#33)))*{c#33 <- `c*`} + -- if (c_1#32*{c_1#32 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#14*{c_2#14 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#34*{c#34 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#15)))*{c_1#33 <- `c_1*`, c_2#15 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#38)*{c#38 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#34))*{c_1#34 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#16))*{c_2#16 <- `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#36)))*{c#36 <- `c*`} + -- if (c_1#35*{c_1#35 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#17*{c_2#17 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#37*{c#37 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#18)))*{c_1#36 <- `c_1*`, c_2#18 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#41)*{c#41 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#37))*{c_1#37 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#19))*{c_2#19 <- `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#39)))*{c#39 <- `c*`} + -- if (c_1#38*{c_1#38 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#20*{c_2#20 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#40*{c#40 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#21)))*{c_1#39 <- `c_1*`, c_2#21 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#44)*{c#44 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#40))*{c_1#40 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#22))*{c_2#22 <- `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#42)))*{c#42 <- `c*`} + -- if (c_1#41*{c_1#41 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#23*{c_2#23 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#43*{c#43 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#24)))*{c_1#42 <- `c_1*`, c_2#24 <- `c_2*`}) + +;; ../../../../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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#47*{c#47 <- `c*#9`})*{`c*#9` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), c#45))*{c#45 <- `c*#7`}*{`c*#7` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#101)))*{iter_0#101 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#43)), !($proj_lane__2(c_2#25)))}*{c_1#43 <- `c_1*`, c_2#25 <- `c_2*`} + -- if (c_1#44*{c_1#44 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#26*{c_2#26 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#46*{c#46 <- `c*#8`}*{`c*#8` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#102)*{iter_0#102 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#45)), !($proj_lane__2(c_2#27)))}*{c_1#45 <- `c_1*`, c_2#27 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#50*{c#50 <- `c*#12`})*{`c*#12` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), c#48))*{c#48 <- `c*#10`}*{`c*#10` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#103)))*{iter_0#103 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#46)), !($proj_lane__2(c_2#28)))}*{c_1#46 <- `c_1*`, c_2#28 <- `c_2*`} + -- if (c_1#47*{c_1#47 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#29*{c_2#29 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#49*{c#49 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#104)*{iter_0#104 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#48)), !($proj_lane__2(c_2#30)))}*{c_1#48 <- `c_1*`, c_2#30 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#53*{c#53 <- `c*#15`})*{`c*#15` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), c#51))*{c#51 <- `c*#13`}*{`c*#13` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#105)))*{iter_0#105 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#49)), !($proj_lane__2(c_2#31)))}*{c_1#49 <- `c_1*`, c_2#31 <- `c_2*`} + -- if (c_1#50*{c_1#50 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#32*{c_2#32 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#52*{c#52 <- `c*#14`}*{`c*#14` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#106)*{iter_0#106 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#33)))}*{c_1#51 <- `c_1*`, c_2#33 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#56*{c#56 <- `c*#18`})*{`c*#18` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), c#54))*{c#54 <- `c*#16`}*{`c*#16` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#107)))*{iter_0#107 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#52)), !($proj_lane__2(c_2#34)))}*{c_1#52 <- `c_1*`, c_2#34 <- `c_2*`} + -- if (c_1#53*{c_1#53 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#35*{c_2#35 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#55*{c#55 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#108)*{iter_0#108 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#36)))}*{c_1#54 <- `c_1*`, c_2#36 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#59*{c#59 <- `c*#21`})*{`c*#21` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), c#57))*{c#57 <- `c*#19`}*{`c*#19` <- `c**`} + -- 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#109))))*{iter_0#109 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#55)))), !($proj_num__1(!($proj_lane__0(c_2#37)))))}*{c_1#55 <- `c_1*`, c_2#37 <- `c_2*`} + -- if (c_1#56*{c_1#56 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#38*{c_2#38 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2)) + -- if (c#58*{c#58 <- `c*#20`}*{`c*#20` <- `c**`} = $setproduct_(syntax lane_, 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#57)))), !($proj_num__1(!($proj_lane__0(c_2#39)))))}*{c_1#57 <- `c_1*`, c_2#39 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#62*{c#62 <- `c*#24`})*{`c*#24` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), c#60))*{c#60 <- `c*#22`}*{`c*#22` <- `c**`} + -- 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#111))))*{iter_0#111 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#58)))), !($proj_num__1(!($proj_lane__0(c_2#40)))))}*{c_1#58 <- `c_1*`, c_2#40 <- `c_2*`} + -- if (c_1#59*{c_1#59 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#41*{c_2#41 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2)) + -- if (c#61*{c#61 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, 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#60)))), !($proj_num__1(!($proj_lane__0(c_2#42)))))}*{c_1#60 <- `c_1*`, c_2#42 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#65*{c#65 <- `c*#27`})*{`c*#27` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), c#63))*{c#63 <- `c*#25`}*{`c*#25` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#113)))*{iter_0#113 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#61)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#1)))}*{c_1#61 <- `c_1*`, c_2#43 <- `c_2*`, c_3#1 <- `c_3*`} + -- if (c_1#62*{c_1#62 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#44*{c_2#44 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c_3#2*{c_3#2 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_3)) + -- if (c#64*{c#64 <- `c*#26`}*{`c*#26` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#114)*{iter_0#114 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#63)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#3)))}*{c_1#63 <- `c_1*`, c_2#45 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#68*{c#68 <- `c*#30`})*{`c*#30` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), c#66))*{c#66 <- `c*#28`}*{`c*#28` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#115)))*{iter_0#115 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#64)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#4)))}*{c_1#64 <- `c_1*`, c_2#46 <- `c_2*`, c_3#4 <- `c_3*`} + -- if (c_1#65*{c_1#65 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#47*{c_2#47 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c_3#5*{c_3#5 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_3)) + -- if (c#67*{c#67 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#116)*{iter_0#116 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#66)), !($proj_lane__2(c_2#48)), !($proj_lane__2(c_3#6)))}*{c_1#66 <- `c_1*`, c_2#48 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#71*{c#71 <- `c*#33`})*{`c*#33` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), c#69))*{c#69 <- `c*#31`}*{`c*#31` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#117)))*{iter_0#117 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#67)), !($proj_lane__2(c_2#49)), !($proj_lane__2(c_3#7)))}*{c_1#67 <- `c_1*`, c_2#49 <- `c_2*`, c_3#7 <- `c_3*`} + -- if (c_1#68*{c_1#68 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#50*{c_2#50 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c_3#8*{c_3#8 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_3)) + -- if (c#70*{c#70 <- `c*#32`}*{`c*#32` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#118)*{iter_0#118 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#69)), !($proj_lane__2(c_2#51)), !($proj_lane__2(c_3#9)))}*{c_1#69 <- `c_1*`, c_2#51 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#74*{c#74 <- `c*#36`})*{`c*#36` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), c#72))*{c#72 <- `c*#34`}*{`c*#34` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#119)))*{iter_0#119 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#70)), !($proj_lane__2(c_2#52)), !($proj_lane__2(c_3#10)))}*{c_1#70 <- `c_1*`, c_2#52 <- `c_2*`, c_3#10 <- `c_3*`} + -- if (c_1#71*{c_1#71 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#53*{c_2#53 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c_3#11*{c_3#11 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_3)) + -- if (c#73*{c#73 <- `c*#35`}*{`c*#35` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#120)*{iter_0#120 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#72)), !($proj_lane__2(c_2#54)), !($proj_lane__2(c_3#12)))}*{c_1#72 <- `c_1*`, c_2#54 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#77*{c#77 <- `c*#39`})*{`c*#39` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), c#75))*{c#75 <- `c*#37`}*{`c*#37` <- `c**`} + -- 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#121))))*{iter_0#121 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#73)))), !($proj_num__1(!($proj_lane__0(c_2#55)))), !($proj_num__1(!($proj_lane__0(c_3#13)))))}*{c_1#73 <- `c_1*`, c_2#55 <- `c_2*`, c_3#13 <- `c_3*`} + -- if (c_1#74*{c_1#74 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#56*{c_2#56 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2)) + -- if (c_3#14*{c_3#14 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_3)) + -- if (c#76*{c#76 <- `c*#38`}*{`c*#38` <- `c**`} = $setproduct_(syntax lane_, 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#75)))), !($proj_num__1(!($proj_lane__0(c_2#57)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#75 <- `c_1*`, c_2#57 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#80*{c#80 <- `c*#42`})*{`c*#42` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), c#78))*{c#78 <- `c*#40`}*{`c*#40` <- `c**`} + -- 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#123))))*{iter_0#123 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#76)))), !($proj_num__1(!($proj_lane__0(c_2#58)))), !($proj_num__1(!($proj_lane__0(c_3#16)))))}*{c_1#76 <- `c_1*`, c_2#58 <- `c_2*`, c_3#16 <- `c_3*`} + -- if (c_1#77*{c_1#77 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#59*{c_2#59 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2)) + -- if (c_3#17*{c_3#17 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_3)) + -- if (c#79*{c#79 <- `c*#41`}*{`c*#41` <- `c**`} = $setproduct_(syntax lane_, 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#78)))), !($proj_num__1(!($proj_lane__0(c_2#60)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#78 <- `c_1*`, c_2#60 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#83)*{c#83 <- `c*`}) + -- 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#81)))*{c#81 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#79)), !($proj_lane__2(c_2#61)))).0)))*{c_1#79 <- `c_1*`, c_2#61 <- `c_2*`} + -- if (c_1#80*{c_1#80 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#62*{c_2#62 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#82*{c#82 <- `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#81)), !($proj_lane__2(c_2#63)))).0))*{c_1#81 <- `c_1*`, c_2#63 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#86)*{c#86 <- `c*`}) + -- 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#84)))*{c#84 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#82)), !($proj_lane__2(c_2#64)))).0)))*{c_1#82 <- `c_1*`, c_2#64 <- `c_2*`} + -- if (c_1#83*{c_1#83 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#65*{c_2#65 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#85*{c#85 <- `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#84)), !($proj_lane__2(c_2#66)))).0))*{c_1#84 <- `c_1*`, c_2#66 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#89)*{c#89 <- `c*`}) + -- 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#87)))*{c#87 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#85)), !($proj_lane__2(c_2#67)))).0)))*{c_1#85 <- `c_1*`, c_2#67 <- `c_2*`} + -- if (c_1#86*{c_1#86 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#68*{c_2#68 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#88*{c#88 <- `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#87)), !($proj_lane__2(c_2#69)))).0))*{c_1#87 <- `c_1*`, c_2#69 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#92)*{c#92 <- `c*`}) + -- 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#90)))*{c#90 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#88)), !($proj_lane__2(c_2#70)))).0)))*{c_1#88 <- `c_1*`, c_2#70 <- `c_2*`} + -- if (c_1#89*{c_1#89 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#71*{c_2#71 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#91*{c#91 <- `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#90)), !($proj_lane__2(c_2#72)))).0))*{c_1#90 <- `c_1*`, c_2#72 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#95)*{c#95 <- `c*`}) + -- 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#93)))*{c#93 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#91)), !($proj_lane__2(c_2#73)))).0)))*{c_1#91 <- `c_1*`, c_2#73 <- `c_2*`} + -- if (c_1#92*{c_1#92 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#74*{c_2#74 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#94*{c#94 <- `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#93)), !($proj_lane__2(c_2#75)))).0))*{c_1#93 <- `c_1*`, c_2#75 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#98)*{c#98 <- `c*`}) + -- 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#96)))*{c#96 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#94)), !($proj_lane__2(c_2#76)))).0)))*{c_1#94 <- `c_1*`, c_2#76 <- `c_2*`} + -- if (c_1#95*{c_1#95 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#77*{c_2#77 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#97*{c#97 <- `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#96)), !($proj_lane__2(c_2#78)))).0))*{c_1#96 <- `c_1*`, c_2#78 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#101)*{c#101 <- `c*`}) + -- 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#99)))*{c#99 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#97)), !($proj_lane__2(c_2#79)))).0)))*{c_1#97 <- `c_1*`, c_2#79 <- `c_2*`} + -- if (c_1#98*{c_1#98 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#80*{c_2#80 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#100*{c#100 <- `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#99)), !($proj_lane__2(c_2#81)))).0))*{c_1#99 <- `c_1*`, c_2#81 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#104)*{c#104 <- `c*`}) + -- 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#102)))*{c#102 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#100)), !($proj_lane__2(c_2#82)))).0)))*{c_1#100 <- `c_1*`, c_2#82 <- `c_2*`} + -- if (c_1#101*{c_1#101 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#83*{c_2#83 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#103*{c#103 <- `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#102)), !($proj_lane__2(c_2#84)))).0))*{c_1#102 <- `c_1*`, c_2#84 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#107).0)))*{c#107 <- `c*`}) + -- 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#105).0)))))*{c#105 <- `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#103)))), !($proj_num__1(!($proj_lane__0(c_2#85)))))).0)))*{c_1#103 <- `c_1*`, c_2#85 <- `c_2*`} + -- if (c_1#104*{c_1#104 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#86*{c_2#86 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2)) + -- if (c#106*{c#106 <- `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#105)))), !($proj_num__1(!($proj_lane__0(c_2#87)))))).0))*{c_1#105 <- `c_1*`, c_2#87 <- `c_2*`}) + -- if ($isize(Inn) = $fsize(F32_Fnn)) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#110).0)))*{c#110 <- `c*`}) + -- 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#108).0)))))*{c#108 <- `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#106)))), !($proj_num__1(!($proj_lane__0(c_2#88)))))).0)))*{c_1#106 <- `c_1*`, c_2#88 <- `c_2*`} + -- if (c_1#107*{c_1#107 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#89*{c_2#89 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2)) + -- if (c#109*{c#109 <- `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#108)))), !($proj_num__1(!($proj_lane__0(c_2#90)))))).0))*{c_1#108 <- `c_1*`, c_2#90 <- `c_2*`}) + -- if ($isize(Inn) = $fsize(F64_Fnn)) + +;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#113)*{c#113 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#109))*{c_1#109 <- `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#111)))*{c#111 <- `c*`} + -- if (c_1#110*{c_1#110 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c#112*{c#112 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#111)), i)*{c_1#111 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#116)*{c#116 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#112))*{c_1#112 <- `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#114)))*{c#114 <- `c*`} + -- if (c_1#113*{c_1#113 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c#115*{c#115 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#114)), i)*{c_1#114 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#119)*{c#119 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#115))*{c_1#115 <- `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#117)))*{c#117 <- `c*`} + -- if (c_1#116*{c_1#116 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c#118*{c#118 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#117)), i)*{c_1#117 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#122)*{c#122 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#118))*{c_1#118 <- `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#120)))*{c#120 <- `c*`} + -- if (c_1#119*{c_1#119 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c#121*{c#121 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#120)), i)*{c_1#120 <- `c_1*`}) + +;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#125)*{c#125 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#121))*{c_1#121 <- `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#123)))*{c#123 <- `c*`} + -- if (c_1#122*{c_1#122 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c#124*{c#124 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#123)), i)*{c_1#123 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#128)*{c#128 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#124))*{c_1#124 <- `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#126)))*{c#126 <- `c*`} + -- if (c_1#125*{c_1#125 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c#127*{c#127 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#126)), i)*{c_1#126 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#131)*{c#131 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#127))*{c_1#127 <- `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#129)))*{c#129 <- `c*`} + -- if (c_1#128*{c_1#128 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c#130*{c#130 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#129)), i)*{c_1#129 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#134)*{c#134 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#130))*{c_1#130 <- `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#132)))*{c#132 <- `c*`} + -- if (c_1#131*{c_1#131 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c#133*{c#133 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#132)), i)*{c_1#132 <- `c_1*`}) + +;; ../../../../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, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- wf_uN: `%%`(32, c) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (if ($proj_lane__2(c_1#133) =/= ?()))*{c_1#133 <- `c_1*`} + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#133)), `%`_iN(0))).0)))*{c_1#133 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + -- if (c_1#134*{c_1#134 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- (if ($proj_lane__2(c_1#135) =/= ?()))*{c_1#135 <- `c_1*`} + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#135)), `%`_iN(0))).0)*{c_1#135 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_1{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- wf_uN: `%%`(32, c) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (if ($proj_lane__2(c_1#136) =/= ?()))*{c_1#136 <- `c_1*`} + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#136)), `%`_iN(0))).0)))*{c_1#136 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + -- if (c_1#137*{c_1#137 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- (if ($proj_lane__2(c_1#138) =/= ?()))*{c_1#138 <- `c_1*`} + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#138)), `%`_iN(0))).0)*{c_1#138 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_2{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- wf_uN: `%%`(32, c) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (if ($proj_lane__2(c_1#139) =/= ?()))*{c_1#139 <- `c_1*`} + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#139)), `%`_iN(0))).0)))*{c_1#139 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + -- if (c_1#140*{c_1#140 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- (if ($proj_lane__2(c_1#141) =/= ?()))*{c_1#141 <- `c_1*`} + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#141)), `%`_iN(0))).0)*{c_1#141 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_3{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- wf_uN: `%%`(32, c) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (if ($proj_lane__2(c_1#142) =/= ?()))*{c_1#142 <- `c_1*`} + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#142)), `%`_iN(0))).0)))*{c_1#142 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + -- if (c_1#143*{c_1#143 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- (if ($proj_lane__2(c_1#144) =/= ?()))*{c_1#144 <- `c_1*`} + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#144)), `%`_iN(0))).0)*{c_1#144 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + +;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#137)*{c#137 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#145))*{c_1#145 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#91))*{c_2#91 <- `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#135)))*{c#135 <- `c*`} + -- if (c_1#146*{c_1#146 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#92*{c_2#92 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#136*{c#136 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#147))*{c_1#147 <- `c_1*`}, !($proj_lane__2(c_2#93)))*{c_2#93 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#140)*{c#140 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#148))*{c_1#148 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#94))*{c_2#94 <- `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#138)))*{c#138 <- `c*`} + -- if (c_1#149*{c_1#149 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#95*{c_2#95 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#139*{c#139 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#150))*{c_1#150 <- `c_1*`}, !($proj_lane__2(c_2#96)))*{c_2#96 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#143)*{c#143 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#151))*{c_1#151 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#97))*{c_2#97 <- `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#141)))*{c#141 <- `c*`} + -- if (c_1#152*{c_1#152 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#98*{c_2#98 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#142*{c#142 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#153))*{c_1#153 <- `c_1*`}, !($proj_lane__2(c_2#99)))*{c_2#99 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#146)*{c#146 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#154))*{c_1#154 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#100))*{c_2#100 <- `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#144)))*{c#144 <- `c*`} + -- if (c_1#155*{c_1#155 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#101*{c_2#101 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#145*{c#145 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#156))*{c_1#156 <- `c_1*`}, !($proj_lane__2(c_2#102)))*{c_2#102 <- `c_2*`}) + +;; ../../../../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, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#128389*{i#128389 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#149*{c#149 <- `c*`})) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c#147))*{c#147 <- `c*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#157))*{c_1#157 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#103))*{c_2#103 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- if (c_1#158*{c_1#158 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#104*{c_2#104 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- (if ($proj_uN_0(i#128396).0 < |c_1#159*{c_1#159 <- `c_1*`} ++ c_2#105*{c_2#105 <- `c_2*`}|))*{i#128396 <- `i*`} + -- if (c#148*{c#148 <- `c*`} = c_1#159*{c_1#159 <- `c_1*`} ++ c_2#105*{c_2#105 <- `c_2*`}[$proj_uN_0(i#128396).0]*{i#128396 <- `i*`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_1{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#128399*{i#128399 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#152*{c#152 <- `c*`})) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c#150))*{c#150 <- `c*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#160))*{c_1#160 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#106))*{c_2#106 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- if (c_1#161*{c_1#161 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#107*{c_2#107 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- (if ($proj_uN_0(i#128406).0 < |c_1#162*{c_1#162 <- `c_1*`} ++ c_2#108*{c_2#108 <- `c_2*`}|))*{i#128406 <- `i*`} + -- if (c#151*{c#151 <- `c*`} = c_1#162*{c_1#162 <- `c_1*`} ++ c_2#108*{c_2#108 <- `c_2*`}[$proj_uN_0(i#128406).0]*{i#128406 <- `i*`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_2{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#128409*{i#128409 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#155*{c#155 <- `c*`})) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c#153))*{c#153 <- `c*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#163))*{c_1#163 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#109))*{c_2#109 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- if (c_1#164*{c_1#164 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#110*{c_2#110 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- (if ($proj_uN_0(i#128416).0 < |c_1#165*{c_1#165 <- `c_1*`} ++ c_2#111*{c_2#111 <- `c_2*`}|))*{i#128416 <- `i*`} + -- if (c#154*{c#154 <- `c*`} = c_1#165*{c_1#165 <- `c_1*`} ++ c_2#111*{c_2#111 <- `c_2*`}[$proj_uN_0(i#128416).0]*{i#128416 <- `i*`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_3{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#128419*{i#128419 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#158*{c#158 <- `c*`})) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c#156))*{c#156 <- `c*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#166))*{c_1#166 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#112))*{c_2#112 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- if (c_1#167*{c_1#167 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#113*{c_2#113 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- (if ($proj_uN_0(i#128426).0 < |c_1#168*{c_1#168 <- `c_1*`} ++ c_2#114*{c_2#114 <- `c_2*`}|))*{i#128426 <- `i*`} + -- if (c#157*{c#157 <- `c*`} = c_1#168*{c_1#168 <- `c_1*`} ++ c_2#114*{c_2#114 <- `c_2*`}[$proj_uN_0(i#128426).0]*{i#128426 <- `i*`}) + +;; ../../../../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}: + `%%%%`(`%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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_1{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_2{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_3{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_4{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_5{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_6{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_7{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_8{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_9{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_10{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_11{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_12{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_13{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_14{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_15{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_16{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_17{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_18{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_19{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_20{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_21{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_22{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_23{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_24{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_25{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))) + +;; ../../../../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}: + `%%%%%`(`%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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_1{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_2{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_3{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_4{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_5{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_6{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_7{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_8{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_9{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_10{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_11{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_12{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_13{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_14{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_15{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_16{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_17{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_18{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_19{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_20{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_21{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_22{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_23{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_24{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_25{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_26{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_27{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_28{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_29{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_30{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_31{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_32{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_33{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_34{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_35{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_36{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_37{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_38{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_39{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_40{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_41{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_42{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_43{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_44{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_45{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_46{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_47{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_48{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_49{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_50{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_51{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_52{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_53{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_54{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_55{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_56{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_57{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_58{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_59{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))) + +;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + +;; ../../../../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}: + `%%%%%`(`%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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_1{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_2{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_3{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_4{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_5{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_6{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_7{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_8{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_9{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_10{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_11{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_12{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_13{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_14{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_15{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_16{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_17{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_18{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_19{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_20{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_21{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_22{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_23{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_24{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_25{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_26{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_27{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_28{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_29{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_30{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_31{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_32{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_33{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_34{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_35{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))) + +;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2857?{half#2857 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2858?{half#2858 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2859?{half#2859 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2860?{half#2860 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2861?{half#2861 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2862?{half#2862 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2863?{half#2863 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2864?{half#2864 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3293?{zero#3293 <- `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#161))?{c#161 <- `c?`})) + -- (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#159))))?{c#159 <- `c?`} + -- if (c#160?{c#160 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3294?{zero#3294 <- `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#164))?{c#164 <- `c?`})) + -- (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#162))))?{c#162 <- `c?`} + -- if (c#163?{c#163 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3295?{zero#3295 <- `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#167))?{c#167 <- `c?`})) + -- (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#165))))?{c#165 <- `c?`} + -- if (c#166?{c#166 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3296?{zero#3296 <- `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#170))?{c#170 <- `c?`})) + -- (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#168))))?{c#168 <- `c?`} + -- if (c#169?{c#169 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3297?{zero#3297 <- `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#173))?{c#173 <- `c?`})) + -- (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#171))))?{c#171 <- `c?`} + -- if (c#172?{c#172 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3298?{zero#3298 <- `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#176))?{c#176 <- `c?`})) + -- (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#174))))?{c#174 <- `c?`} + -- if (c#175?{c#175 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3299?{zero#3299 <- `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#179))?{c#179 <- `c?`})) + -- (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#177))))?{c#177 <- `c?`} + -- if (c#178?{c#178 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3300?{zero#3300 <- `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#182))?{c#182 <- `c?`})) + -- (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#180))))?{c#180 <- `c?`} + -- if (c#181?{c#181 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3301?{zero#3301 <- `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#185))?{c#185 <- `c?`})) + -- (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#183))))?{c#183 <- `c?`} + -- if (c#184?{c#184 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3302?{zero#3302 <- `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#188))?{c#188 <- `c?`})) + -- (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#186))))?{c#186 <- `c?`} + -- if (c#187?{c#187 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3303?{zero#3303 <- `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#191))?{c#191 <- `c?`})) + -- (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#189))))?{c#189 <- `c?`} + -- if (c#190?{c#190 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3304?{zero#3304 <- `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#194))?{c#194 <- `c?`})) + -- (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#192))))?{c#192 <- `c?`} + -- if (c#193?{c#193 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3305?{zero#3305 <- `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#197))?{c#197 <- `c?`})) + -- (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#195))))?{c#195 <- `c?`} + -- if (c#196?{c#196 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3306?{zero#3306 <- `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#200))?{c#200 <- `c?`})) + -- (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#198))))?{c#198 <- `c?`} + -- if (c#199?{c#199 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3307?{zero#3307 <- `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#203))?{c#203 <- `c?`})) + -- (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#201))))?{c#201 <- `c?`} + -- if (c#202?{c#202 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3308?{zero#3308 <- `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#206))?{c#206 <- `c?`})) + -- (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#204))))?{c#204 <- `c?`} + -- if (c#205?{c#205 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3309?{zero#3309 <- `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#209))?{c#209 <- `c?`})) + -- (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#207))))?{c#207 <- `c?`} + -- if (c#208?{c#208 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3310?{zero#3310 <- `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#212))?{c#212 <- `c?`})) + -- (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#210))))?{c#210 <- `c?`} + -- if (c#211?{c#211 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3311?{zero#3311 <- `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#215))?{c#215 <- `c?`})) + -- (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#213))))?{c#213 <- `c?`} + -- if (c#214?{c#214 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3312?{zero#3312 <- `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#218))?{c#218 <- `c?`})) + -- (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#216))))?{c#216 <- `c?`} + -- if (c#217?{c#217 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3313?{zero#3313 <- `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#221))?{c#221 <- `c?`})) + -- (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#219))))?{c#219 <- `c?`} + -- if (c#220?{c#220 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3314?{zero#3314 <- `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#224))?{c#224 <- `c?`})) + -- (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#222))))?{c#222 <- `c?`} + -- if (c#223?{c#223 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3315?{zero#3315 <- `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#227))?{c#227 <- `c?`})) + -- (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#225))))?{c#225 <- `c?`} + -- if (c#226?{c#226 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3316?{zero#3316 <- `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#230))?{c#230 <- `c?`})) + -- (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#228))))?{c#228 <- `c?`} + -- if (c#229?{c#229 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3317?{zero#3317 <- `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#233))?{c#233 <- `c?`})) + -- (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#231))))?{c#231 <- `c?`} + -- if (c#232?{c#232 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3318?{zero#3318 <- `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#236))?{c#236 <- `c?`})) + -- (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#234))))?{c#234 <- `c?`} + -- if (c#235?{c#235 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3319?{zero#3319 <- `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#239))?{c#239 <- `c?`})) + -- (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#237))))?{c#237 <- `c?`} + -- if (c#238?{c#238 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3320?{zero#3320 <- `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#242))?{c#242 <- `c?`})) + -- (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#240))))?{c#240 <- `c?`} + -- if (c#241?{c#241 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3321?{zero#3321 <- `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#245))?{c#245 <- `c?`})) + -- (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#243))))?{c#243 <- `c?`} + -- if (c#244?{c#244 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3322?{zero#3322 <- `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#248))?{c#248 <- `c?`})) + -- (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#246))))?{c#246 <- `c?`} + -- if (c#247?{c#247 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3323?{zero#3323 <- `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#251))?{c#251 <- `c?`})) + -- (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#249))))?{c#249 <- `c?`} + -- if (c#250?{c#250 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3324?{zero#3324 <- `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#254))?{c#254 <- `c?`})) + -- (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#252))))?{c#252 <- `c?`} + -- if (c#253?{c#253 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_56{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#257))*{c#257 <- `c*`}) + -- (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#255))))*{c#255 <- `c*`} + -- if (c#256*{c#256 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_57{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#260))*{c#260 <- `c*`}) + -- (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#258))))*{c#258 <- `c*`} + -- if (c#259*{c#259 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_58{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#263))*{c#263 <- `c*`}) + -- (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#261))))*{c#261 <- `c*`} + -- if (c#262*{c#262 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_59{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#266))*{c#266 <- `c*`}) + -- (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#264))))*{c#264 <- `c*`} + -- if (c#265*{c#265 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_60{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#269))*{c#269 <- `c*`}) + -- (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#267))))*{c#267 <- `c*`} + -- if (c#268*{c#268 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_61{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#272))*{c#272 <- `c*`}) + -- (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#270))))*{c#270 <- `c*`} + -- if (c#271*{c#271 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_62{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#275))*{c#275 <- `c*`}) + -- (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#273))))*{c#273 <- `c*`} + -- if (c#274*{c#274 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_63{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#278))*{c#278 <- `c*`}) + -- (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#276))))*{c#276 <- `c*`} + -- if (c#277*{c#277 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_64{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#281))*{c#281 <- `c*`}) + -- (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#279))))*{c#279 <- `c*`} + -- if (c#280*{c#280 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_65{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#284))*{c#284 <- `c*`}) + -- (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#282))))*{c#282 <- `c*`} + -- if (c#283*{c#283 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_66{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#287))*{c#287 <- `c*`}) + -- (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#285))))*{c#285 <- `c*`} + -- if (c#286*{c#286 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_67{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#290))*{c#290 <- `c*`}) + -- (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#288))))*{c#288 <- `c*`} + -- if (c#289*{c#289 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_68{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#293))*{c#293 <- `c*`}) + -- (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#291))))*{c#291 <- `c*`} + -- if (c#292*{c#292 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_69{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#296))*{c#296 <- `c*`}) + -- (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#294))))*{c#294 <- `c*`} + -- if (c#295*{c#295 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_70{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#299))*{c#299 <- `c*`}) + -- (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#297))))*{c#297 <- `c*`} + -- if (c#298*{c#298 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_71{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#302))*{c#302 <- `c*`}) + -- (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#300))))*{c#300 <- `c*`} + -- if (c#301*{c#301 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + +;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1, v) + -- if (|`var_2*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M))), c_1#169))*{c_1#169 <- `c_1*`} + -- (wf_lane_: `%%`(Lnn_2, c#303))*{c#303 <- `c*#43`}*{`c*#43` <- `c**`} + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) + -- if ((var_0 = ?()) /\ (var_1 = ?())) + -- if (c_1#170*{c_1#170 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1)) + -- if (c#304*{c#304 <- `c*#44`}*{`c*#44` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`})) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}| > 0) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}) + + ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**, `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_1*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `c_1*`} + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#172))*{c_1#172 <- `c_1*`} + -- (wf_lane_: `%%`(Lnn_2, c#306))*{c#306 <- `c*#46`}*{`c*#46` <- `c**`} + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- if (var_0 = ?(half)) + -- if (c_1#173*{c_1#173 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2]) + -- if (c#307*{c#307 <- `c*#47`}*{`c*#47` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`})) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}| > 0) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}) + + ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**, var_2 : lane_, `var_1*` : lane_**, var_0 : zero?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- fun_zero: `%%`(Lnn_2, var_2) + -- if (|`var_1*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `c_1*`} + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#175))*{c_1#175 <- `c_1*`} + -- (wf_lane_: `%%`(Lnn_2, c#309))*{c#309 <- `c*#49`}*{`c*#49` <- `c**`} + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- if (var_0 = ?(ZERO_zero)) + -- if (c_1#176*{c_1#176 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)) + -- if (c#310*{c#310 <- `c*#50`}*{`c*#50` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [var_2]^M_1{})) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}| > 0) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}) + +;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_1{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_2{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_3{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_4{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_5{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_6{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_7{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))) + +;; ../../../../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) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + + ;; ../../../../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) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + + ;; ../../../../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) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + + ;; ../../../../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) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../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}: + `%%%%%`(`%`_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 + rule fun_vswizzlop__case_1{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 +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#129110*{i#129110 <- `i*`}, v_1, v_2, var_0) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) + -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + +;; ../../../../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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#178))*{c_1#178 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#115))*{c_2#115 <- `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#1)))*{c'_1#1 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#1)))*{c'_2#1 <- `c'_2*`} + -- if (c_1#179*{c_1#179 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#116*{c_2#116 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#180) =/= ?()))*{c_1#180 <- `c_1*`} + -- if (c'_1#2*{c'_1#2 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#117) =/= ?()))*{c_2#117 <- `c_2*`} + -- if (c'_2#2*{c'_2#2 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#117)))*{c_2#117 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#3)*{c'_1#3 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#181))*{c_1#181 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#118))*{c_2#118 <- `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#4)))*{c'_1#4 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#4)))*{c'_2#4 <- `c'_2*`} + -- if (c_1#182*{c_1#182 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#119*{c_2#119 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#183) =/= ?()))*{c_1#183 <- `c_1*`} + -- if (c'_1#5*{c'_1#5 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#183)))*{c_1#183 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#120) =/= ?()))*{c_2#120 <- `c_2*`} + -- if (c'_2#5*{c'_2#5 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#120)))*{c_2#120 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#6)*{c'_1#6 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#184))*{c_1#184 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#121))*{c_2#121 <- `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#7)))*{c'_1#7 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#7)))*{c'_2#7 <- `c'_2*`} + -- if (c_1#185*{c_1#185 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#122*{c_2#122 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#186) =/= ?()))*{c_1#186 <- `c_1*`} + -- if (c'_1#8*{c'_1#8 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#123) =/= ?()))*{c_2#123 <- `c_2*`} + -- if (c'_2#8*{c'_2#8 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#123)))*{c_2#123 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#9)*{c'_1#9 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#187))*{c_1#187 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#124))*{c_2#124 <- `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#10)))*{c'_1#10 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#10)))*{c'_2#10 <- `c'_2*`} + -- if (c_1#188*{c_1#188 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#125*{c_2#125 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#189) =/= ?()))*{c_1#189 <- `c_1*`} + -- if (c'_1#11*{c'_1#11 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#189)))*{c_1#189 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#126) =/= ?()))*{c_2#126 <- `c_2*`} + -- if (c'_2#11*{c'_2#11 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#126)))*{c_2#126 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#12)*{c'_1#12 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#190))*{c_1#190 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#127))*{c_2#127 <- `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#13)))*{c'_1#13 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#13)))*{c'_2#13 <- `c'_2*`} + -- if (c_1#191*{c_1#191 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#128*{c_2#128 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#192) =/= ?()))*{c_1#192 <- `c_1*`} + -- if (c'_1#14*{c'_1#14 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#129) =/= ?()))*{c_2#129 <- `c_2*`} + -- if (c'_2#14*{c'_2#14 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#129)))*{c_2#129 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#15)*{c'_1#15 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#193))*{c_1#193 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#130))*{c_2#130 <- `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#16)))*{c'_1#16 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#16)))*{c'_2#16 <- `c'_2*`} + -- if (c_1#194*{c_1#194 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#131*{c_2#131 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#195) =/= ?()))*{c_1#195 <- `c_1*`} + -- if (c'_1#17*{c'_1#17 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#195)))*{c_1#195 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#132) =/= ?()))*{c_2#132 <- `c_2*`} + -- if (c'_2#17*{c'_2#17 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#132)))*{c_2#132 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#18)*{c'_1#18 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#196))*{c_1#196 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#133))*{c_2#133 <- `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#19)))*{c'_1#19 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#19)))*{c'_2#19 <- `c'_2*`} + -- if (c_1#197*{c_1#197 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#134*{c_2#134 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#198) =/= ?()))*{c_1#198 <- `c_1*`} + -- if (c'_1#20*{c'_1#20 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#135) =/= ?()))*{c_2#135 <- `c_2*`} + -- if (c'_2#20*{c'_2#20 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#135)))*{c_2#135 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#21)*{c'_1#21 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#199))*{c_1#199 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#136))*{c_2#136 <- `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#22)))*{c'_1#22 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#22)))*{c'_2#22 <- `c'_2*`} + -- if (c_1#200*{c_1#200 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#137*{c_2#137 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#201) =/= ?()))*{c_1#201 <- `c_1*`} + -- if (c'_1#23*{c'_1#23 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#201)))*{c_1#201 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#138) =/= ?()))*{c_2#138 <- `c_2*`} + -- if (c'_2#23*{c'_2#23 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#138)))*{c_2#138 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#24)*{c'_1#24 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#202))*{c_1#202 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#139))*{c_2#139 <- `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#25)))*{c'_1#25 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#25)))*{c'_2#25 <- `c'_2*`} + -- if (c_1#203*{c_1#203 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#140*{c_2#140 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#204) =/= ?()))*{c_1#204 <- `c_1*`} + -- if (c'_1#26*{c'_1#26 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#141) =/= ?()))*{c_2#141 <- `c_2*`} + -- if (c'_2#26*{c'_2#26 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#141)))*{c_2#141 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#27)*{c'_1#27 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#205))*{c_1#205 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#142))*{c_2#142 <- `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#28)))*{c'_1#28 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#28)))*{c'_2#28 <- `c'_2*`} + -- if (c_1#206*{c_1#206 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#143*{c_2#143 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#207) =/= ?()))*{c_1#207 <- `c_1*`} + -- if (c'_1#29*{c'_1#29 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#207)))*{c_1#207 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#144) =/= ?()))*{c_2#144 <- `c_2*`} + -- if (c'_2#29*{c'_2#29 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#144)))*{c_2#144 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#30)*{c'_1#30 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#208))*{c_1#208 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#145))*{c_2#145 <- `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#31)))*{c'_1#31 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#31)))*{c'_2#31 <- `c'_2*`} + -- if (c_1#209*{c_1#209 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#146*{c_2#146 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#210) =/= ?()))*{c_1#210 <- `c_1*`} + -- if (c'_1#32*{c'_1#32 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#147) =/= ?()))*{c_2#147 <- `c_2*`} + -- if (c'_2#32*{c'_2#32 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#147)))*{c_2#147 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#33)*{c'_1#33 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#211))*{c_1#211 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#148))*{c_2#148 <- `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#34)))*{c'_1#34 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#34)))*{c'_2#34 <- `c'_2*`} + -- if (c_1#212*{c_1#212 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#149*{c_2#149 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#213) =/= ?()))*{c_1#213 <- `c_1*`} + -- if (c'_1#35*{c'_1#35 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#213)))*{c_1#213 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#150) =/= ?()))*{c_2#150 <- `c_2*`} + -- if (c'_2#35*{c'_2#35 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#150)))*{c_2#150 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#36)*{c'_1#36 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#214))*{c_1#214 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#151))*{c_2#151 <- `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#37)))*{c'_1#37 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#37)))*{c'_2#37 <- `c'_2*`} + -- if (c_1#215*{c_1#215 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#152*{c_2#152 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#216) =/= ?()))*{c_1#216 <- `c_1*`} + -- if (c'_1#38*{c'_1#38 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#216)))*{c_1#216 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#153) =/= ?()))*{c_2#153 <- `c_2*`} + -- if (c'_2#38*{c'_2#38 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#153)))*{c_2#153 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#39)*{c'_1#39 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#217))*{c_1#217 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#154))*{c_2#154 <- `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#40)))*{c'_1#40 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#40)))*{c'_2#40 <- `c'_2*`} + -- if (c_1#218*{c_1#218 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#155*{c_2#155 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#219) =/= ?()))*{c_1#219 <- `c_1*`} + -- if (c'_1#41*{c'_1#41 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#219)))*{c_1#219 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#156) =/= ?()))*{c_2#156 <- `c_2*`} + -- if (c'_2#41*{c'_2#41 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#156)))*{c_2#156 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#42)*{c'_1#42 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#220))*{c_1#220 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#157))*{c_2#157 <- `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#43)))*{c'_1#43 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#43)))*{c'_2#43 <- `c'_2*`} + -- if (c_1#221*{c_1#221 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#158*{c_2#158 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#222) =/= ?()))*{c_1#222 <- `c_1*`} + -- if (c'_1#44*{c'_1#44 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#222)))*{c_1#222 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#159) =/= ?()))*{c_2#159 <- `c_2*`} + -- if (c'_2#44*{c'_2#44 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#159)))*{c_2#159 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#45)*{c'_1#45 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#223))*{c_1#223 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#160))*{c_2#160 <- `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#46)))*{c'_1#46 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#46)))*{c'_2#46 <- `c'_2*`} + -- if (c_1#224*{c_1#224 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#161*{c_2#161 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#225) =/= ?()))*{c_1#225 <- `c_1*`} + -- if (c'_1#47*{c'_1#47 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#225)))*{c_1#225 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#162) =/= ?()))*{c_2#162 <- `c_2*`} + -- if (c'_2#47*{c'_2#47 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#162)))*{c_2#162 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#48)*{c'_1#48 <- `c'_1*`} ++ 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#129288*{i#129288 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- (wf_uN: `%%`(N, `%`_uN(j_1#1)))*{j_1#1 <- `j_1*`} + -- (wf_uN: `%%`(N, `%`_uN(j_2#1)))*{j_2#1 <- `j_2*`} + -- if ($concat_(syntax N, [j_1#2 j_2#2]*{j_1#2 <- `j_1*`, j_2#2 <- `j_2*`}) = $proj_uN_0(i#129291).0*{i#129291 <- `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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#314)*{c#314 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#226))*{c_1#226 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#49))*{c'_1#49 <- `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#312)))*{c#312 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#227*{c_1#227 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#50*{c'_1#50 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#228)))*{c_1#228 <- `c_1*`}) + -- if (c#313*{c#313 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#51*{c'_1#51 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#317)*{c#317 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#229))*{c_1#229 <- `c_1*`} + -- (wf_uN: `%%`($lsize($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#315)))*{c#315 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#230*{c_1#230 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#53*{c'_1#53 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#231)))*{c_1#231 <- `c_1*`}) + -- if (c#316*{c#316 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#54*{c'_1#54 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#320)*{c#320 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#232))*{c_1#232 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#55))*{c'_1#55 <- `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#318)))*{c#318 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#233*{c_1#233 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#56*{c'_1#56 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#234)))*{c_1#234 <- `c_1*`}) + -- if (c#319*{c#319 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#57*{c'_1#57 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#323)*{c#323 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#235))*{c_1#235 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#58))*{c'_1#58 <- `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#321)))*{c#321 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#236*{c_1#236 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#59*{c'_1#59 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#237)))*{c_1#237 <- `c_1*`}) + -- if (c#322*{c#322 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#60*{c'_1#60 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#326)*{c#326 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#238))*{c_1#238 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#61))*{c'_1#61 <- `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#324)))*{c#324 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#239*{c_1#239 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#62*{c'_1#62 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#240)))*{c_1#240 <- `c_1*`}) + -- if (c#325*{c#325 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#63*{c'_1#63 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#329)*{c#329 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#241))*{c_1#241 <- `c_1*`} + -- (wf_uN: `%%`($lsize($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#327)))*{c#327 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#242*{c_1#242 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#65*{c'_1#65 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#243)))*{c_1#243 <- `c_1*`}) + -- if (c#328*{c#328 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#66*{c'_1#66 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#332)*{c#332 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#244))*{c_1#244 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#67))*{c'_1#67 <- `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#330)))*{c#330 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#245*{c_1#245 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#68*{c'_1#68 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#246)))*{c_1#246 <- `c_1*`}) + -- if (c#331*{c#331 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#69*{c'_1#69 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#335)*{c#335 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#247))*{c_1#247 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#70))*{c'_1#70 <- `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#333)))*{c#333 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#248*{c_1#248 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#71*{c'_1#71 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#249)))*{c_1#249 <- `c_1*`}) + -- if (c#334*{c#334 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#72*{c'_1#72 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#338)*{c#338 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#250))*{c_1#250 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#73))*{c'_1#73 <- `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#336)))*{c#336 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#251*{c_1#251 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#74*{c'_1#74 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#252)))*{c_1#252 <- `c_1*`}) + -- if (c#337*{c#337 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#75*{c'_1#75 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#341)*{c#341 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#253))*{c_1#253 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#76))*{c'_1#76 <- `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#339)))*{c#339 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#254*{c_1#254 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#77*{c'_1#77 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#255)))*{c_1#255 <- `c_1*`}) + -- if (c#340*{c#340 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#78*{c'_1#78 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#344)*{c#344 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#256))*{c_1#256 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#79))*{c'_1#79 <- `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#342)))*{c#342 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#257*{c_1#257 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#80*{c'_1#80 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#258)))*{c_1#258 <- `c_1*`}) + -- if (c#343*{c#343 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#81*{c'_1#81 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#347)*{c#347 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#259))*{c_1#259 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#82))*{c'_1#82 <- `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#345)))*{c#345 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#260*{c_1#260 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#83*{c'_1#83 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#261)))*{c_1#261 <- `c_1*`}) + -- if (c#346*{c#346 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#84*{c'_1#84 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#350)*{c#350 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#262))*{c_1#262 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#85))*{c'_1#85 <- `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#348)))*{c#348 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#263*{c_1#263 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#86*{c'_1#86 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#264)))*{c_1#264 <- `c_1*`}) + -- if (c#349*{c#349 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#87*{c'_1#87 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#353)*{c#353 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#265))*{c_1#265 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#88))*{c'_1#88 <- `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#351)))*{c#351 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#266*{c_1#266 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#89*{c'_1#89 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#267)))*{c_1#267 <- `c_1*`}) + -- if (c#352*{c#352 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#90*{c'_1#90 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#356)*{c#356 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#268))*{c_1#268 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#91))*{c'_1#91 <- `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#354)))*{c#354 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#269*{c_1#269 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#92*{c'_1#92 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#270)))*{c_1#270 <- `c_1*`}) + -- if (c#355*{c#355 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#93*{c'_1#93 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#359)*{c#359 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#271))*{c_1#271 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#94))*{c'_1#94 <- `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#357)))*{c#357 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#272*{c_1#272 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#95*{c'_1#95 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#273)))*{c_1#273 <- `c_1*`}) + -- if (c#358*{c#358 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#96*{c'_1#96 <- `c'_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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + +;; ../../../../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*`} + -- (wf_uN: `%%`(N, j_1#3))*{j_1#3 <- `j_1*`} + -- (wf_uN: `%%`(N, j_2#3))*{j_2#3 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#4 j_2#4]*{j_1#4 <- `j_1*`, j_2#4 <- `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*`} + -- (wf_uN: `%%`(N, j_1#5))*{j_1#5 <- `j_1*`} + -- (wf_uN: `%%`(N, j_2#5))*{j_2#5 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#6 j_2#6]*{j_1#6 <- `j_1*`, j_2#6 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#362)*{c#362 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#274))*{c_1#274 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#163))*{c_2#163 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#97))*{c'_1#97 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_2#49))*{c'_2#49 <- `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#360)))*{c#360 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#275*{c_1#275 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#164*{c_2#164 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#98*{c'_1#98 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#276)))*{c_1#276 <- `c_1*`}) + -- if (c'_2#50*{c'_2#50 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#165)))*{c_2#165 <- `c_2*`}) + -- if (c#361*{c#361 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#99*{c'_1#99 <- `c'_1*`}, c'_2#51*{c'_2#51 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#365)*{c#365 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#277))*{c_1#277 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#166))*{c_2#166 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#100))*{c'_1#100 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), 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#363)))*{c#363 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#278*{c_1#278 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#167*{c_2#167 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#101*{c'_1#101 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#279)))*{c_1#279 <- `c_1*`}) + -- if (c'_2#53*{c'_2#53 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#168)))*{c_2#168 <- `c_2*`}) + -- if (c#364*{c#364 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#368)*{c#368 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#280))*{c_1#280 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#169))*{c_2#169 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#103))*{c'_1#103 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_2#55))*{c'_2#55 <- `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#366)))*{c#366 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#281*{c_1#281 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#170*{c_2#170 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#104*{c'_1#104 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#282)))*{c_1#282 <- `c_1*`}) + -- if (c'_2#56*{c'_2#56 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#171)))*{c_2#171 <- `c_2*`}) + -- if (c#367*{c#367 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#105*{c'_1#105 <- `c'_1*`}, c'_2#57*{c'_2#57 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#371)*{c#371 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#283))*{c_1#283 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#172))*{c_2#172 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#106))*{c'_1#106 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_2#58))*{c'_2#58 <- `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#369)))*{c#369 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#284*{c_1#284 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#173*{c_2#173 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#107*{c'_1#107 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#285)))*{c_1#285 <- `c_1*`}) + -- if (c'_2#59*{c'_2#59 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#174)))*{c_2#174 <- `c_2*`}) + -- if (c#370*{c#370 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#374)*{c#374 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#286))*{c_1#286 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#175))*{c_2#175 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#109))*{c'_1#109 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_2#61))*{c'_2#61 <- `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#372)))*{c#372 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#287*{c_1#287 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#176*{c_2#176 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#110*{c'_1#110 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#288)))*{c_1#288 <- `c_1*`}) + -- if (c'_2#62*{c'_2#62 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#177)))*{c_2#177 <- `c_2*`}) + -- if (c#373*{c#373 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#111*{c'_1#111 <- `c'_1*`}, c'_2#63*{c'_2#63 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#377)*{c#377 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#289))*{c_1#289 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#178))*{c_2#178 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#112))*{c'_1#112 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), 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#375)))*{c#375 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#290*{c_1#290 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#179*{c_2#179 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#113*{c'_1#113 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#291)))*{c_1#291 <- `c_1*`}) + -- if (c'_2#65*{c'_2#65 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#180)))*{c_2#180 <- `c_2*`}) + -- if (c#376*{c#376 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#114*{c'_1#114 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#380)*{c#380 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#292))*{c_1#292 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#181))*{c_2#181 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#115))*{c'_1#115 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_2#67))*{c'_2#67 <- `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#378)))*{c#378 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#293*{c_1#293 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#182*{c_2#182 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#116*{c'_1#116 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#294)))*{c_1#294 <- `c_1*`}) + -- if (c'_2#68*{c'_2#68 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#183)))*{c_2#183 <- `c_2*`}) + -- if (c#379*{c#379 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#117*{c'_1#117 <- `c'_1*`}, c'_2#69*{c'_2#69 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#383)*{c#383 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#295))*{c_1#295 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#184))*{c_2#184 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#118))*{c'_1#118 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_2#70))*{c'_2#70 <- `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#381)))*{c#381 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#296*{c_1#296 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#185*{c_2#185 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#119*{c'_1#119 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#297)))*{c_1#297 <- `c_1*`}) + -- if (c'_2#71*{c'_2#71 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#186)))*{c_2#186 <- `c_2*`}) + -- if (c#382*{c#382 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#120*{c'_1#120 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#386)*{c#386 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#298))*{c_1#298 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#187))*{c_2#187 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#121))*{c'_1#121 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_2#73))*{c'_2#73 <- `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#384)))*{c#384 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#299*{c_1#299 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#188*{c_2#188 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#122*{c'_1#122 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#300)))*{c_1#300 <- `c_1*`}) + -- if (c'_2#74*{c'_2#74 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#189)))*{c_2#189 <- `c_2*`}) + -- if (c#385*{c#385 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#123*{c'_1#123 <- `c'_1*`}, c'_2#75*{c'_2#75 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#389)*{c#389 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#301))*{c_1#301 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#190))*{c_2#190 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#124))*{c'_1#124 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_2#76))*{c'_2#76 <- `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#387)))*{c#387 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#302*{c_1#302 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#191*{c_2#191 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#125*{c'_1#125 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#303)))*{c_1#303 <- `c_1*`}) + -- if (c'_2#77*{c'_2#77 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#192)))*{c_2#192 <- `c_2*`}) + -- if (c#388*{c#388 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#126*{c'_1#126 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#392)*{c#392 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#304))*{c_1#304 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#193))*{c_2#193 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#127))*{c'_1#127 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_2#79))*{c'_2#79 <- `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#390)))*{c#390 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#305*{c_1#305 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#194*{c_2#194 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#128*{c'_1#128 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#306)))*{c_1#306 <- `c_1*`}) + -- if (c'_2#80*{c'_2#80 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#195)))*{c_2#195 <- `c_2*`}) + -- if (c#391*{c#391 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#129*{c'_1#129 <- `c'_1*`}, c'_2#81*{c'_2#81 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#395)*{c#395 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#307))*{c_1#307 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#196))*{c_2#196 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#130))*{c'_1#130 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_2#82))*{c'_2#82 <- `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#393)))*{c#393 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#308*{c_1#308 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#197*{c_2#197 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#131*{c'_1#131 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#309)))*{c_1#309 <- `c_1*`}) + -- if (c'_2#83*{c'_2#83 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#198)))*{c_2#198 <- `c_2*`}) + -- if (c#394*{c#394 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#132*{c'_1#132 <- `c'_1*`}, c'_2#84*{c'_2#84 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#398)*{c#398 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#310))*{c_1#310 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#199))*{c_2#199 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#133))*{c'_1#133 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_2#85))*{c'_2#85 <- `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#396)))*{c#396 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#311*{c_1#311 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#200*{c_2#200 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#134*{c'_1#134 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#312)))*{c_1#312 <- `c_1*`}) + -- if (c'_2#86*{c'_2#86 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#201)))*{c_2#201 <- `c_2*`}) + -- if (c#397*{c#397 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#135*{c'_1#135 <- `c'_1*`}, c'_2#87*{c'_2#87 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#401)*{c#401 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#313))*{c_1#313 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#202))*{c_2#202 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#136))*{c'_1#136 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_2#88))*{c'_2#88 <- `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#399)))*{c#399 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#314*{c_1#314 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#203*{c_2#203 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#137*{c'_1#137 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#315)))*{c_1#315 <- `c_1*`}) + -- if (c'_2#89*{c'_2#89 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#204)))*{c_2#204 <- `c_2*`}) + -- if (c#400*{c#400 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#138*{c'_1#138 <- `c'_1*`}, c'_2#90*{c'_2#90 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#404)*{c#404 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#316))*{c_1#316 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#205))*{c_2#205 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#139))*{c'_1#139 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_2#91))*{c'_2#91 <- `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#402)))*{c#402 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#317*{c_1#317 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#206*{c_2#206 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#140*{c'_1#140 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#318)))*{c_1#318 <- `c_1*`}) + -- if (c'_2#92*{c'_2#92 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#207)))*{c_2#207 <- `c_2*`}) + -- if (c#403*{c#403 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#141*{c'_1#141 <- `c'_1*`}, c'_2#93*{c'_2#93 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#407)*{c#407 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#319))*{c_1#319 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#208))*{c_2#208 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#142))*{c'_1#142 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_2#94))*{c'_2#94 <- `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#405)))*{c#405 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#320*{c_1#320 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#209*{c_2#209 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#143*{c'_1#143 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#321)))*{c_1#321 <- `c_1*`}) + -- if (c'_2#95*{c'_2#95 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#210)))*{c_2#210 <- `c_2*`}) + -- if (c#406*{c#406 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#144*{c'_1#144 <- `c'_1*`}, c'_2#96*{c'_2#96 <- `c'_2*`})) + +;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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 + rule fun_vextbinop___case_17{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 + rule fun_vextbinop___case_18{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 + rule fun_vextbinop___case_19{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 + rule fun_vextbinop___case_20{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 + rule fun_vextbinop___case_21{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 + rule fun_vextbinop___case_22{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 + rule fun_vextbinop___case_23{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 + rule fun_vextbinop___case_24{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 + rule fun_vextbinop___case_25{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 + rule fun_vextbinop___case_26{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 + rule fun_vextbinop___case_27{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 + rule fun_vextbinop___case_28{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 + rule fun_vextbinop___case_29{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 + rule fun_vextbinop___case_30{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 + rule fun_vextbinop___case_31{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 + rule fun_vextbinop___case_32{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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + +;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + +;; ../../../../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 +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) + +;; ../../../../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 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 +relation fun_packfield__before_fun_packfield__case_9: `%%`(storagetype, val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_8{i : uN}: + `%%`(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) + -- wf_fieldval: `%`(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_7{i : uN}: + `%%`(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) + -- wf_fieldval: `%`(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_6{val : val}: + `%%`(I32_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_5{val : val}: + `%%`(I64_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_4{val : val}: + `%%`(F32_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_3{val : val}: + `%%`(F64_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_2{val : val}: + `%%`(V128_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_1{`null?` : null?, heaptype : heaptype, val : val}: + `%%`(REF_storagetype(`null?`, heaptype), val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_0{val : val}: + `%%`(BOT_storagetype, val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_packfield_: `%%%`(storagetype, val, fieldval?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_0{val : val}: + `%%%`(BOT_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_1{`null?` : null?, heaptype : heaptype, val : val}: + `%%%`(REF_storagetype(`null?`, heaptype), val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_2{val : val}: + `%%%`(V128_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_3{val : val}: + `%%%`(F64_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_4{val : val}: + `%%%`(F32_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_5{val : val}: + `%%%`(I64_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_6{val : val}: + `%%%`(I32_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_7{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 + rule fun_packfield__case_8{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))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_9{x0 : storagetype, x1 : val}: + `%%%`(x0, x1, ?()) + -- ~ fun_packfield__before_fun_packfield__case_9: `%%`(x0, x1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_unpackfield__before_fun_unpackfield__case_72: `%%%`(storagetype, sx?, fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_71{sx : sx, i : uN}: + `%%%`(I16_storagetype, ?(sx), PACK_fieldval(I16_packtype, i)) + -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_70{sx : sx, i : uN}: + `%%%`(I8_storagetype, ?(sx), PACK_fieldval(I8_packtype, 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 + rule fun_unpackfield__case_69{numtype : numtype, var_0 : num_}: + `%%%`(I32_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_68{numtype : numtype, var_0 : num_}: + `%%%`(I64_storagetype, ?(), CONST_fieldval(numtype, var_0)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_0{`val*` : val*}: - `%`(_VALS_result(`val*`)) - -- (wf_val: `%`(val))*{val <- `val*`} + rule fun_unpackfield__case_67{numtype : numtype, var_0 : num_}: + `%%%`(F32_storagetype, ?(), CONST_fieldval(numtype, var_0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_1{exnaddr : exnaddr}: - `%`(`(REF.EXN_ADDR%)THROW_REF`_result(exnaddr)) + rule fun_unpackfield__case_66{numtype : numtype, var_0 : num_}: + `%%%`(F64_storagetype, ?(), CONST_fieldval(numtype, var_0)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule result_case_2: - `%`(TRAP_result) + rule fun_unpackfield__case_65{numtype : numtype, var_0 : num_}: + `%%%`(V128_storagetype, ?(), CONST_fieldval(numtype, var_0)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax hostfunc = - | `...` + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_64{numtype : numtype, var_0 : num_, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), CONST_fieldval(numtype, var_0)) -;; ../../../../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 + rule fun_unpackfield__case_63{numtype : numtype, var_0 : num_}: + `%%%`(BOT_storagetype, ?(), CONST_fieldval(numtype, var_0)) -;; ../../../../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} + rule fun_unpackfield__case_62{vectype : vectype, var_1 : vec_}: + `%%%`(I32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule funccode_case_1: - `%`(`...`_funccode) + rule fun_unpackfield__case_61{vectype : vectype, var_1 : vec_}: + `%%%`(I64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax taginst = -{ - TYPE tagtype -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_60{vectype : vectype, var_1 : vec_}: + `%%%`(F32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) -;; ../../../../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 fun_unpackfield__case_59{vectype : vectype, var_1 : vec_}: + `%%%`(F64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax globalinst = -{ - TYPE globaltype, - VALUE val -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_58{vectype : vectype, var_1 : vec_}: + `%%%`(V128_storagetype, ?(), VCONST_fieldval(vectype, var_1)) -;; ../../../../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) + rule fun_unpackfield__case_57{vectype : vectype, var_1 : vec_, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), VCONST_fieldval(vectype, 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 + rule fun_unpackfield__case_56{vectype : vectype, var_1 : vec_}: + `%%%`(BOT_storagetype, ?(), VCONST_fieldval(vectype, var_1)) -;; ../../../../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} + rule fun_unpackfield__case_55{u31 : u31}: + `%%%`(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax tableinst = -{ - TYPE tabletype, - REFS ref* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_54{u31 : u31}: + `%%%`(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) -;; ../../../../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} + rule fun_unpackfield__case_53{u31 : u31}: + `%%%`(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_52{u31 : u31}: + `%%%`(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_51{u31 : u31}: + `%%%`(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_50{u31 : u31, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_49{u31 : u31}: + `%%%`(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_48: + `%%%`(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_47: + `%%%`(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_46: + `%%%`(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_45: + `%%%`(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_44: + `%%%`(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_43{`null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_42: + `%%%`(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_41{structaddr : structaddr}: + `%%%`(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_40{structaddr : structaddr}: + `%%%`(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_39{structaddr : structaddr}: + `%%%`(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_38{structaddr : structaddr}: + `%%%`(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_37{structaddr : structaddr}: + `%%%`(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_36{structaddr : structaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_35{structaddr : structaddr}: + `%%%`(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_34{arrayaddr : arrayaddr}: + `%%%`(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_33{arrayaddr : arrayaddr}: + `%%%`(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_32{arrayaddr : arrayaddr}: + `%%%`(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_31{arrayaddr : arrayaddr}: + `%%%`(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_30{arrayaddr : arrayaddr}: + `%%%`(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_29{arrayaddr : arrayaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_28{arrayaddr : arrayaddr}: + `%%%`(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_27{funcaddr : funcaddr}: + `%%%`(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_26{funcaddr : funcaddr}: + `%%%`(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_25{funcaddr : funcaddr}: + `%%%`(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_24{funcaddr : funcaddr}: + `%%%`(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_23{funcaddr : funcaddr}: + `%%%`(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_22{funcaddr : funcaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_21{funcaddr : funcaddr}: + `%%%`(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_20{exnaddr : exnaddr}: + `%%%`(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_19{exnaddr : exnaddr}: + `%%%`(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_18{exnaddr : exnaddr}: + `%%%`(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_17{exnaddr : exnaddr}: + `%%%`(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_16{exnaddr : exnaddr}: + `%%%`(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_15{exnaddr : exnaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_14{exnaddr : exnaddr}: + `%%%`(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_13{hostaddr : hostaddr}: + `%%%`(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_12{hostaddr : hostaddr}: + `%%%`(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_11{hostaddr : hostaddr}: + `%%%`(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_10{hostaddr : hostaddr}: + `%%%`(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_9{hostaddr : hostaddr}: + `%%%`(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_8{hostaddr : hostaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_7{hostaddr : hostaddr}: + `%%%`(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_6{ref : ref}: + `%%%`(I32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_5{ref : ref}: + `%%%`(I64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_4{ref : ref}: + `%%%`(F32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_3{ref : ref}: + `%%%`(F64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_2{ref : ref}: + `%%%`(V128_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_1{ref : ref, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_0{ref : ref}: + `%%%`(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax funcinst = -{ - TYPE deftype, - MODULE moduleinst, - CODE funccode -} +relation fun_unpackfield_: `%%%%`(storagetype, sx?, fieldval, val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_0{ref : ref}: + `%%%%`(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_1{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 + rule fun_unpackfield__case_2{ref : ref}: + `%%%%`(V128_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_3{ref : ref}: + `%%%%`(F64_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_4{ref : ref}: + `%%%%`(F32_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_5{ref : ref}: + `%%%%`(I64_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_6{ref : ref}: + `%%%%`(I32_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_7{hostaddr : hostaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_8{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 + rule fun_unpackfield__case_9{hostaddr : hostaddr}: + `%%%%`(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_10{hostaddr : hostaddr}: + `%%%%`(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_11{hostaddr : hostaddr}: + `%%%%`(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_12{hostaddr : hostaddr}: + `%%%%`(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_13{hostaddr : hostaddr}: + `%%%%`(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_14{exnaddr : exnaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_15{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 + rule fun_unpackfield__case_16{exnaddr : exnaddr}: + `%%%%`(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_17{exnaddr : exnaddr}: + `%%%%`(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_18{exnaddr : exnaddr}: + `%%%%`(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_19{exnaddr : exnaddr}: + `%%%%`(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_20{exnaddr : exnaddr}: + `%%%%`(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_21{funcaddr : funcaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_22{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 + rule fun_unpackfield__case_23{funcaddr : funcaddr}: + `%%%%`(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_24{funcaddr : funcaddr}: + `%%%%`(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_25{funcaddr : funcaddr}: + `%%%%`(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_26{funcaddr : funcaddr}: + `%%%%`(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_27{funcaddr : funcaddr}: + `%%%%`(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_28{arrayaddr : arrayaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_29{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 + rule fun_unpackfield__case_30{arrayaddr : arrayaddr}: + `%%%%`(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_31{arrayaddr : arrayaddr}: + `%%%%`(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_32{arrayaddr : arrayaddr}: + `%%%%`(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_33{arrayaddr : arrayaddr}: + `%%%%`(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) -;; ../../../../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) + rule fun_unpackfield__case_34{arrayaddr : arrayaddr}: + `%%%%`(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax datainst = -{ - BYTES byte* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_35{structaddr : structaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) -;; ../../../../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} + rule fun_unpackfield__case_36{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 -syntax eleminst = -{ - TYPE elemtype, - REFS ref* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_37{structaddr : structaddr}: + `%%%%`(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) -;; ../../../../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} + rule fun_unpackfield__case_38{structaddr : structaddr}: + `%%%%`(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax packval = - | PACK(packtype : packtype, iN) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_39{structaddr : structaddr}: + `%%%%`(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) -;; ../../../../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) + rule fun_unpackfield__case_40{structaddr : structaddr}: + `%%%%`(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) -;; ../../../../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 + rule fun_unpackfield__case_41{structaddr : structaddr}: + `%%%%`(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) -;; ../../../../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) + rule fun_unpackfield__case_42: + `%%%%`(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) ;; ../../../../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) + rule fun_unpackfield__case_43{`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 - rule fieldval_case_2{u31 : u31}: - `%`(`REF.I31_NUM`_fieldval(u31)) - -- wf_uN: `%%`(31, u31) + rule fun_unpackfield__case_44: + `%%%%`(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_3: - `%`(`REF.NULL_ADDR`_fieldval) + rule fun_unpackfield__case_45: + `%%%%`(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_4{structaddr : structaddr}: - `%`(`REF.STRUCT_ADDR`_fieldval(structaddr)) + rule fun_unpackfield__case_46: + `%%%%`(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_5{arrayaddr : arrayaddr}: - `%`(`REF.ARRAY_ADDR`_fieldval(arrayaddr)) + rule fun_unpackfield__case_47: + `%%%%`(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_6{funcaddr : funcaddr}: - `%`(`REF.FUNC_ADDR`_fieldval(funcaddr)) + rule fun_unpackfield__case_48: + `%%%%`(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_7{exnaddr : exnaddr}: - `%`(`REF.EXN_ADDR`_fieldval(exnaddr)) + rule fun_unpackfield__case_49{u31 : u31}: + `%%%%`(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_8{hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_fieldval(hostaddr)) + rule fun_unpackfield__case_50{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 - rule fieldval_case_9{ref : ref}: - `%`(`REF.EXTERN`_fieldval(ref)) - -- wf_ref: `%`(ref) + rule fun_unpackfield__case_51{u31 : u31}: + `%%%%`(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) ;; ../../../../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 fun_unpackfield__case_52{u31 : u31}: + `%%%%`(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax structinst = -{ - TYPE deftype, - FIELDS fieldval* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_53{u31 : u31}: + `%%%%`(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) -;; ../../../../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} + rule fun_unpackfield__case_54{u31 : u31}: + `%%%%`(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax arrayinst = -{ - TYPE deftype, - FIELDS fieldval* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_55{u31 : u31}: + `%%%%`(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) -;; ../../../../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} + rule fun_unpackfield__case_56{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 -syntax exninst = -{ - TAG tagaddr, - FIELDS val* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_57{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 -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} + rule fun_unpackfield__case_58{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 -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 + rule fun_unpackfield__case_59{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 -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} + rule fun_unpackfield__case_60{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 -syntax state = - | `%;%`(store : store, frame : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_61{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 -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) + rule fun_unpackfield__case_62{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 -syntax config = - | `%;%`(state : state, `instr*` : instr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_63{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 -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*`} + rule fun_unpackfield__case_64{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 $Ki : nat ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $Ki = 1024 + rule fun_unpackfield__case_65{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 $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)) + rule fun_unpackfield__case_66{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 $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 + rule fun_unpackfield__case_67{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 + rule fun_unpackfield__case_68{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_(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) + rule fun_unpackfield__case_69{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_{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 fun_unpackfield__case_70{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 + rule fun_unpackfield__case_71{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)))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_72{x0 : storagetype, x1 : sx?, x2 : fieldval}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_unpackfield__before_fun_unpackfield__case_72: `%%%`(x0, x1, x2) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -9256,9 +15513,9 @@ 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*`}) + 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*{xa <- `xa*`}) = $tagsxa(xa*{xa <- `xa*`}) + 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 @@ -9269,9 +15526,9 @@ 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*`}) + 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*{xa <- `xa*`}) = $globalsxa(xa*{xa <- `xa*`}) + 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 @@ -9282,9 +15539,9 @@ 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*`}) + 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*{xa <- `xa*`}) = $memsxa(xa*{xa <- `xa*`}) + 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 @@ -9295,9 +15552,9 @@ 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*`}) + 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*{xa <- `xa*`}) = $tablesxa(xa*{xa <- `xa*`}) + 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 @@ -9308,9 +15565,9 @@ 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*`}) + 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*{xa <- `xa*`}) = $funcsxa(xa*{xa <- `xa*`}) + 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 @@ -9439,112 +15696,168 @@ def $local(state : state, localidx : localidx) : val? 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 $with_local(state : state, localidx : localidx, val : val) : state +relation fun_with_local: `%%%%`(state, localidx, 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)]) + rule fun_with_local_case_0{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 -def $with_global(state : state, globalidx : globalidx, val : val) : state +relation fun_with_global: `%%%%`(state, globalidx, 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)) + rule fun_with_global_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.GLOBALS_moduleinst|) -- 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 -def $with_table(state : state, tableidx : tableidx, nat : nat, ref : ref) : state +relation fun_with_table: `%%%%%`(state, tableidx, nat, 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)) + rule fun_with_table_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.TABLES_moduleinst|) -- 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 -def $with_tableinst(state : state, tableidx : tableidx, tableinst : tableinst) : state +relation fun_with_tableinst: `%%%%`(state, tableidx, 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)) + rule fun_with_tableinst_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.TABLES_moduleinst|) -- 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 -def $with_mem(state : state, memidx : memidx, nat : nat, nat : nat, byte*) : state +relation fun_with_mem: `%%%%%%`(state, memidx, 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))) + rule fun_with_mem_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.MEMS_moduleinst|) + -- 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 -def $with_meminst(state : state, memidx : memidx, meminst : meminst) : state +relation fun_with_meminst: `%%%%`(state, memidx, 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)) + rule fun_with_meminst_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.MEMS_moduleinst|) -- 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 -def $with_elem(state : state, elemidx : elemidx, ref*) : state +relation fun_with_elem: `%%%%`(state, 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))) + rule fun_with_elem_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.ELEMS_moduleinst|) + -- 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 -def $with_data(state : state, dataidx : dataidx, byte*) : state +relation fun_with_data: `%%%%`(state, 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))) + rule fun_with_data_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.DATAS_moduleinst|) + -- 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))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_struct(state : state, structaddr : structaddr, nat : nat, fieldval : fieldval) : state +relation fun_with_struct: `%%%%%`(state, structaddr, nat, 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)) + rule fun_with_struct_case_0{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 +relation fun_with_array: `%%%%%`(state, arrayaddr, nat, 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)) + rule fun_with_array_case_0{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 +relation fun_add_structinst: `%%%`(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_add_structinst_case_0{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 -def $add_arrayinst(state : state, arrayinst*) : state +relation fun_add_arrayinst: `%%%`(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))) + rule fun_add_arrayinst_case_0{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 -def $add_exninst(state : state, exninst*) : state +relation fun_add_exninst: `%%%`(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))) + rule fun_add_exninst_case_0{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 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, at : addrtype, i : uN, `j?` : u64?, rt : reftype, `r'*` : ref*, i' : uN}(tableinst, n, r) = ?(tableinst') + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, at : addrtype, i : uN, `j?` : u64?, rt : reftype, `r'*` : ref*, i' : uN}: + `%%%`(tableinst, n, r) -- 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{}}) - -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS r'*{r' <- `r'*`}}) - -- 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))) - def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() - -- otherwise + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#3?{j#3 <- `j?`}), rt), REFS r'#3*{r'#3 <- `r'*`}}) + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#5*{r'#5 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#5).0))?{j#5 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) ;; ../../../../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 - def $growmem{meminst : meminst, n : nat, meminst' : meminst, at : addrtype, i : uN, `j?` : u64?, `b*` : byte*, i' : uN}(meminst, n) = ?(meminst') + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, at : addrtype, i : uN, `j?` : u64?, rt : reftype, `r'*` : ref*, i' : uN}: + `%%%%`(tableinst, n, r, ?(tableinst')) + -- wf_tableinst: `%`(tableinst') + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#3?{j#3 <- `j?`}), rt), REFS r'#3*{r'#3 <- `r'*`}}) + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#5*{r'#5 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#5).0))?{j#5 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + + ;; ../../../../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 fun_growmem_before_fun_growmem_case_1: `%%`(meminst, nat) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, at : addrtype, i : uN, `j?` : u64?, `b*` : byte*, i' : uN}: + `%%`(meminst, n) -- 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)){}}) - -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES b*{b <- `b*`}}) - -- 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))) - def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() - -- otherwise + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#8?{j#8 <- `j?`})), BYTES b#7*{b#7 <- `b*`}}) + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#9?{j#9 <- `j?`})), BYTES b#8*{b#8 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#9*{b#9 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#10).0))?{j#10 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + +;; ../../../../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, at : addrtype, i : uN, `j?` : u64?, `b*` : byte*, i' : uN}: + `%%%`(meminst, n, ?(meminst')) + -- wf_meminst: `%`(meminst') + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#8?{j#8 <- `j?`})), BYTES b#7*{b#7 <- `b*`}}) + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#9?{j#9 <- `j?`})), BYTES b#8*{b#8 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#9*{b#9 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#10).0))?{j#10 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + + ;; ../../../../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.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) @@ -9583,28 +15896,28 @@ 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))) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) -- if (a < |s.STRUCTS_store|) -- if (s.STRUCTS_store[a].TYPE_structinst = 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))) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) -- if (a < |s.ARRAYS_store|) -- if (s.ARRAYS_store[a].TYPE_arrayinst = 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))) -- wf_store: `%`(s) -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) - -- wf_reftype: `%`(REF_reftype(?(), (dt : deftype <: heaptype))) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a].TYPE_funcinst = dt) @@ -9652,21 +15965,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)) -- wf_store: `%`(s) -- wf_num: `%`(num) -- Num_ok: `%|-%:%`(s, num, nt) ;; ../../../../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)) -- wf_store: `%`(s) -- wf_vec: `%`(vec) -- Vec_ok: `%|-%:%`(s, vec, vt) ;; ../../../../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)) -- wf_store: `%`(s) -- wf_ref: `%`(ref) -- wf_reftype: `%`(rt) @@ -9684,7 +15997,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)) -- wf_store: `%`(s) -- wf_val: `%`(val) -- wf_valtype: `%`(t) @@ -9692,7 +16005,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)) -- wf_store: `%`(s) -- wf_packval: `%`(packval) -- Packval_ok: `%|-%:%`(s, packval, pt) @@ -9736,9 +16049,9 @@ relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:121.1-123.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))) -- wf_store: `%`(s) - -- wf_externtype: `%`(FUNC_externtype((funcinst.TYPE_funcinst : deftype <: typeuse))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) -- if (a < |s.FUNCS_store|) -- if (s.FUNCS_store[a] = funcinst) @@ -9754,35 +16067,45 @@ 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 fun_inst_reftype: `%%%`(moduleinst, 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*)) + 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_globaltype(moduleinst : moduleinst, globaltype : globaltype) : globaltype +relation fun_inst_globaltype: `%%%`(moduleinst, 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*)) + 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 -def $inst_memtype(moduleinst : moduleinst, memtype : memtype) : memtype +relation fun_inst_memtype: `%%%`(moduleinst, 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*)) + 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_tabletype(moduleinst : moduleinst, tabletype : tabletype) : tabletype +relation fun_inst_tabletype: `%%%`(moduleinst, 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*)) + 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.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)]) + `%`([$instr_val(val) BR_ON_NULL_instr(l)]) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) -- wf_instr: `%`(BR_instr(l)) @@ -9793,7 +16116,7 @@ relation `Step_pure_before_br_on_null-addr`: `%`(instr*) 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)]) + `%`([$instr_val(val) BR_ON_NON_NULL_instr(l)]) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) -- wf_val: `%`(`REF.NULL_ADDR`_val) @@ -9803,7 +16126,7 @@ relation `Step_pure_before_br_on_non_null-addr`: `%`(instr*) 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]) + `%`([$instr_ref(ref) `REF.IS_NULL`_instr]) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.IS_NULL`_instr) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -9814,7 +16137,7 @@ relation `Step_pure_before_ref.is_null-false`: `%`(instr*) 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]) + `%`([$instr_ref(ref) `REF.AS_NON_NULL`_instr]) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) -- wf_instr: `%`(TRAP_instr) @@ -9825,7 +16148,7 @@ relation `Step_pure_before_ref.as_non_null-addr`: `%`(instr*) 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]) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) -- wf_instr: `%`(`REF.EQ`_instr) @@ -9837,17 +16160,17 @@ relation `Step_pure_before_ref.eq-true`: `%`(instr*) 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]) + `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) -- 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)))) - -- ~ `Step_pure_before_ref.eq-true`: `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) + -- ~ `Step_pure_before_ref.eq-true`: `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) -- if (ref_1 = ref_2) ;; ../../../../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]) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) -- wf_instr: `%`(`REF.EQ`_instr) @@ -9859,7 +16182,7 @@ relation `Step_pure_before_ref.eq-false`: `%`(instr*) 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]) + `%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr]) -- wf_ref: `%`(ref) -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) -- wf_instr: `%`(`REF.NULL_ADDR`_instr) @@ -9880,13 +16203,13 @@ 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)]) + `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_1)]) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9896,7 +16219,7 @@ 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)]) + `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_2)]) -- wf_val: `%`(val_1) -- wf_val: `%`(val_2) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) @@ -9924,26 +16247,26 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../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'*`}) - -- 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'*`}) + -- 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 ($proj_uN_0(l).0 = 0) ;; ../../../../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)))]) - -- wf_instr: `%`(`LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, (val : val <: instr)*{val <- `val*`} ++ [BR_instr(l)] ++ instr*{instr <- `instr*`})) + `%~>%`([`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)))]) + -- 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)))) -- if ($proj_uN_0(l).0 > 0) ;; ../../../../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 @@ -9983,7 +16306,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../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)]) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) -- wf_instr: `%`(BR_instr(l)) @@ -9992,14 +16315,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)]) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NULL_instr(l)) - -- ~ `Step_pure_before_br_on_null-addr`: `%`([(val : val <: instr) BR_ON_NULL_instr(l)]) + -- ~ `Step_pure_before_br_on_null-addr`: `%`([$instr_val(val) 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)], []) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) -- wf_val: `%`(`REF.NULL_ADDR`_val) @@ -10007,58 +16330,58 @@ 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)]) -- wf_val: `%`(val) -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) -- wf_instr: `%`(BR_instr(l)) - -- ~ `Step_pure_before_br_on_non_null-addr`: `%`([(val : val <: instr) BR_ON_NON_NULL_instr(l)]) + -- ~ `Step_pure_before_br_on_non_null-addr`: `%`([$instr_val(val) BR_ON_NON_NULL_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*`})) ;; ../../../../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*`})) ;; ../../../../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]) -- (wf_val: `%`(val))*{val <- `val*`} -- (wf_instr: `%`(instr))*{instr <- `instr*`} -- wf_instr: `%`(TRAP_instr) @@ -10084,7 +16407,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)) @@ -10099,7 +16422,7 @@ relation Step_pure: `%~>%`(instr*, instr*) ;; ../../../../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)))]) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.IS_NULL`_instr) -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))) @@ -10108,15 +16431,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)))]) + `%~>%`([$instr_ref(ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.IS_NULL`_instr) -- wf_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]) + -- ~ `Step_pure_before_ref.is_null-false`: `%`([$instr_ref(ref) `REF.IS_NULL`_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]) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) -- wf_instr: `%`(TRAP_instr) @@ -10125,14 +16448,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)]) -- wf_ref: `%`(ref) -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) - -- ~ `Step_pure_before_ref.as_non_null-addr`: `%`([(ref : ref <: instr) `REF.AS_NON_NULL`_instr]) + -- ~ `Step_pure_before_ref.as_non_null-addr`: `%`([$instr_ref(ref) `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)))]) -- wf_ref: `%`(ref_1) -- wf_ref: `%`(ref_2) -- wf_instr: `%`(`REF.EQ`_instr) @@ -10142,22 +16465,22 @@ 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)))]) -- 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)))) - -- ~ `Step_pure_before_ref.eq-true`: `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) + -- ~ `Step_pure_before_ref.eq-true`: `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) -- if (ref_1 = ref_2) ;; ../../../../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)))]) -- 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)))) - -- ~ `Step_pure_before_ref.eq-false`: `%`([(ref_1 : ref <: instr) (ref_2 : ref <: instr) `REF.EQ`_instr]) + -- ~ `Step_pure_before_ref.eq-false`: `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `i31.get-null`{sx : sx}: @@ -10175,7 +16498,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)) @@ -10183,7 +16506,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]) -- wf_ref: `%`(ref) -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) -- wf_instr: `%`(`REF.NULL_ADDR`_instr) @@ -10191,10 +16514,10 @@ 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)]) -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) -- wf_instr: `%`(`REF.EXTERN`_instr(ref)) - -- ~ `Step_pure_before_extern.convert_any-addr`: `%`([(ref : ref <: instr) `EXTERN.CONVERT_ANY`_instr]) + -- ~ `Step_pure_before_extern.convert_any-addr`: `%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr]) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `any.convert_extern-null`: @@ -10204,54 +16527,59 @@ 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)]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) - -- if (|$unop_(nt, unop, c_1)| > 0) - -- if (c <- $unop_(nt, unop, c_1)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) - -- if ($unop_(nt, unop, c_1) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- if (|$binop_(nt, binop, c_1, c_2)| > 0) - -- if (c <- $binop_(nt, binop, c_1, c_2)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(TRAP_instr) - -- if ($binop_(nt, binop, c_1, c_2) = []) + -- if (var_0 = []) + -- 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_}: + rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_, var_0 : u32}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(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)) = var_0) + -- fun_testop_: `%%%%`(nt, testop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: @@ -10264,21 +16592,23 @@ relation Step_pure: `%~>%`(instr*, instr*) -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) ;; ../../../../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)]) -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(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 (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) - -- if ($cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- if (var_0 = []) + -- 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_}: @@ -10311,249 +16641,275 @@ relation Step_pure: `%~>%`(instr*, instr*) -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vvtestop{c_1 : vec_, c : num_}: + rule vvtestop{c_1 : vec_, c : num_, var_0 : u32}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(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)) = var_0) + -- fun_inez_: `%%%`($vsize(V128_vectype), c_1, var_0) ;; ../../../../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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$vunop_(sh, vunop, c_1)| > 0) - -- if (c <- $vunop_(sh, vunop, c_1)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) - -- if ($vunop_(sh, vunop, c_1) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- if (|$vbinop_(sh, vbinop, c_1, c_2)| > 0) - -- if (c <- $vbinop_(sh, vbinop, c_1, c_2)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- 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) - -- if ($vbinop_(sh, vbinop, c_1, c_2) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- if (|$vternop_(sh, vternop, c_1, c_2, c_3)| > 0) - -- if (c <- $vternop_(sh, vternop, c_1, c_2, c_3)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- 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) - -- if ($vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- if (var_0 = []) + -- 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)]) - -- (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*` : uN*}: + `%~>%`([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)]) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_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))) - -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(M)), c_1)) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) + -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0(var_0).0*{var_0 <- `var_0*`})) + -- if (|`var_0*`| = |`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*`})) + -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_0))*{var_0 <- `var_0*`, i <- `i*`} ;; ../../../../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)]) -- 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)) - -- if (c = $vrelop_(sh, vrelop, c_1, c_2)) + -- if (c = var_0) + -- 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)]) -- 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)) + -- if (c = var_0) -- if ($proj_num__0(i) =/= ?()) - -- if (c = $vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- 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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(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) + -- 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)]) -- 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)) - -- if (c = $vswizzlop_(sh, swizzlop, c_1, c_2)) + -- if (c = var_0) + -- 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)]) -- 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)) - -- if (c = $vshufflop_(sh, i*{i <- `i*`}, c_1, c_2)) + -- if (c = var_0) + -- 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_}: + rule vsplat{Lnn : Lnn, c_1 : num_, M : M, c : vec_, var_0 : lane_}: `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) -- 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))) - -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lpacknum_(Lnn, c_1)^M{})) + -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), var_0^M{})) + -- fun_lpacknum_: `%%%`(Lnn, c_1, var_0) ;; ../../../../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)]) + `%~>%`([VCONST_instr(V128_vectype, c_1) VEXTRACT_LANE_instr(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M)), ?(), i)], [CONST_instr(nt, c_2)]) -- 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))) - -- 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($lanetype_numtype(nt), `%`_dim(M))), mk_lane__0_lane_(nt, c_2)) + -- wf_shape: `%`(`%X%`_shape($lanetype_numtype(nt), `%`_dim(M))) + -- 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]) ;; ../../../../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)]) -- 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))) -- 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)|) + -- 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])))) ;; ../../../../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_}: + rule vreplace_lane{c_1 : vec_, Lnn : Lnn, c_2 : num_, M : M, i : laneidx, c : vec_, var_0 : lane_}: `%~>%`([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)]) -- 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))) - -- 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)])) + -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = var_0])) + -- fun_lpacknum_: `%%%`(Lnn, c_2, var_0) ;; ../../../../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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if ($vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- if (var_0 = 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)]) -- 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)) - -- if ($vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- if (var_0 = 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)]) -- 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)) - -- if ($vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- if (var_0 = 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)]) -- 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)) - -- if (c = $vnarrowop__($proj_ishape_0(sh_1).0, $proj_ishape_0(sh_2).0, sx, c_1, c_2)) + -- if (c = var_0) + -- 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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (c = $vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- if (c = var_0) + -- 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*`})) - -- 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*`}))) - -- Expand: `%~~%`($type(z, x), `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*`}))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), [], `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) + -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#5*{t_1#5 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `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?`})))) + rule fun_blocktype__case_1{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 `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, rt : reftype}: - `%`(`%;%`_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, rt : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_reftype: `%`(rt) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) 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)])) -- wf_instr: `%`(BR_instr(l)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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, rt : reftype}: - `%`(`%;%`_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, rt : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_reftype: `%`(rt) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) 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_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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) @@ -10597,8 +16953,8 @@ 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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) @@ -10607,15 +16963,15 @@ relation `Step_read_before_table.fill-zero`: `%`(config) 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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `Step_read_before_table.fill-zero`: `%`(`%;%`_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 (n = 0) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) @@ -10624,8 +16980,8 @@ relation `Step_read_before_table.fill-succ`: `%`(config) 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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -10635,15 +16991,15 @@ relation `Step_read_before_table.copy-zero`: `%`(config) 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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `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) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -10653,32 +17009,32 @@ relation `Step_read_before_table.copy-le`: `%`(config) 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)])) - -- 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)])) + -- 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)) -- if ($proj_num__0(i_1) =/= ?()) - -- 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($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) -- if ($proj_num__0(i_2) =/= ?()) - -- 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_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)) - -- ~ `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)])) + -- ~ `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) ;; ../../../../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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `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) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -10688,8 +17044,8 @@ relation `Step_read_before_table.copy-gt`: `%`(config) 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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) @@ -10699,15 +17055,15 @@ relation `Step_read_before_table.init-zero`: `%`(config) 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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `Step_read_before_table.init-zero`: `%`(`%;%`_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 (n = 0) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) @@ -10717,8 +17073,8 @@ relation `Step_read_before_table.init-succ`: `%`(config) 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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) @@ -10727,15 +17083,15 @@ relation `Step_read_before_memory.fill-zero`: `%`(config) 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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `Step_read_before_memory.fill-zero`: `%`(`%;%`_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 (n = 0) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) @@ -10744,8 +17100,8 @@ relation `Step_read_before_memory.fill-succ`: `%`(config) 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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -10755,15 +17111,15 @@ relation `Step_read_before_memory.copy-zero`: `%`(config) 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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `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) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -10772,33 +17128,34 @@ relation `Step_read_before_memory.copy-le`: `%`(config) ;; ../../../../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)])) - -- 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)) + 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, var_0 : memarg}: + `%`(`%;%`_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_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, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) -- if ($proj_num__0(i_1) =/= ?()) - -- 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($numtype_addrtype(at_1), mk_num__0_num_(at_1, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) -- if ($proj_num__0(i_2) =/= ?()) - -- 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_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)) - -- ~ `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)])) + -- ~ `Step_read_before_memory.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))) `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) + -- fun_memarg0: `%`(var_0) ;; ../../../../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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `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) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -10808,8 +17165,8 @@ relation `Step_read_before_memory.copy-gt`: `%`(config) 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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) @@ -10819,15 +17176,15 @@ relation `Step_read_before_memory.init-zero`: `%`(config) relation `Step_read_before_memory.init-succ`: `%`(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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `Step_read_before_memory.init-zero`: `%`(`%;%`_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 (n = 0) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) @@ -10836,32 +17193,34 @@ relation `Step_read_before_memory.init-succ`: `%`(config) ;; ../../../../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, rt' : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) + rule `ref.test-true_0`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) -- wf_reftype: `%`(rt') - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `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(1)))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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, rt' : reftype}: - `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + rule `ref.cast-succeed_0`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_reftype: `%`(rt') - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) @@ -10871,15 +17230,15 @@ 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-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)])) - -- 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)])) - -- ~ `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)])) + -- 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)])) + -- ~ `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) ;; ../../../../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)])) - -- 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)])) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) @@ -10935,7 +17294,7 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype}: + rule `array.copy-le_0`{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, var_0 : sx??}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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_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)) @@ -10953,8 +17312,9 @@ relation `Step_read_before_array.copy-gt`: `%`(config) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 ($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 (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx}: @@ -11029,15 +17389,16 @@ relation `Step_read_before_array.init_elem-succ`: `%`(config) ;; ../../../../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_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: + rule `array.init_data-oob2_0`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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_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))) -- 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|) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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}: @@ -11058,15 +17419,16 @@ relation `Step_read_before_array.init_data-num`: `%`(config) -- if (n = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype}: + rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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_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))) -- 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|) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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}: @@ -11080,60 +17442,64 @@ relation `Step_read_before_array.init_data-num`: `%`(config) ;; ../../../../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*`})]) - -- 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*`})]) + -- 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 ($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*`}))) + -- 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*`})]) - -- 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*`})]) + -- 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 ($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*`}))) + -- 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, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)]), [(ref : ref <: instr) BR_instr(l)]) + rule `br_on_cast-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : 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)]) -- wf_reftype: `%`(rt) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) 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)])) -- wf_instr: `%`(BR_instr(l)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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)]) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_instr(l, rt_1, rt_2)])) - -- ~ `Step_read_before_br_on_cast-fail`: `%`(`%;%`_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)]) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- ~ `Step_read_before_br_on_cast-fail`: `%`(`%;%`_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, rt : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [(ref : ref <: instr)]) + rule `br_on_cast_fail-succeed`{s : store, f : frame, ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) -- wf_reftype: `%`(rt) - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) 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_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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)]) - -- 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)]) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_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)])) + -- ~ `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)])) ;; ../../../../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))]) + `%~>%`(`%;%`_config(z, [CALL_instr(x)]), [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr($typeuse_deftype($funcinst(z)[a].TYPE_funcinst))]) -- if (a < |$funcinst(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 ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) @@ -11144,52 +17510,54 @@ relation Step_read: `%~>%`(config, instr*) -- 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*`})])]) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)^n{val <- `val*`} ++ [`REF.FUNC_ADDR`_instr(a) CALL_REF_instr(yy)])) + 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*, `var_0*` : val??*}: + `%~>%`(`%;%`_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*`})])]) + -- 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*`})) - -- (if ($default_(t) =/= ?()))*{t <- `t*`} - -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- (if (var_0 =/= ?()))*{var_0 <- `var_0*`} + -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !(var_0)*{var_0 <- `var_0*`}, MODULE fi.MODULE_funcinst}) -- 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 (f = {LOCALS ?(val)^n{val <- `val*`} ++ !($default_(t))*{t <- `t*`}, MODULE fi.MODULE_funcinst}) + -- if (f = {LOCALS ?(val)^n{val <- `val*`} ++ !(var_0)*{var_0 <- `var_0*`}, MODULE fi.MODULE_funcinst}) + -- if (|`var_0*`| = |`t*`|) + -- (fun_default_: `%%`(t, var_0))*{var_0 <- `var_0*`, t <- `t*`} ;; ../../../../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))]) + `%~>%`(`%;%`_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)|) -- 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 ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) ;; ../../../../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)]) - -- 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*`})])) + `%~>%`(`%;%`_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)]) + -- 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*`}))) @@ -11204,8 +17572,8 @@ 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]) - -- wf_config: `%`(`%;%`_config(z, (val : val <: instr)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `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]) + -- 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) -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `instr*`} =/= [])) @@ -11233,7 +17601,7 @@ 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)]) -- (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)) @@ -11244,7 +17612,7 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../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)]) -- (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)) @@ -11275,82 +17643,83 @@ relation Step_read: `%~>%`(config, instr*) -- ~ `Step_read_before_throw_ref-handler-next`: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [catch] ++ 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*`})])]) - -- 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*`})])]) + -- 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 ($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*`}))) + -- 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)]) -- wf_val: `%`(val) -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) -- if ($local(z, x) = ?(val)) ;; ../../../../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)]) -- wf_val: `%`(val) -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) -- if ($global(z, x).VALUE_globalinst = val) ;; ../../../../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]) - -- 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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) -- wf_instr: `%`(TRAP_instr) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) ;; ../../../../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_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)))]) -- 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)) -- if (|$table(z, x).REFS_tableinst| = n) -- if ($table(z, x).TYPE_tableinst = `%%%`_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]) - -- 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]) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) ;; ../../../../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)]), []) - -- 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)])) - -- ~ `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)]), []) + -- 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)])) + -- ~ `Step_read_before_table.fill-zero`: `%`(`%;%`_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 (n = 0) ;; ../../../../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)]) + `%~>%`(`%;%`_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) =/= ?()) - -- 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_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)) - -- ~ `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)])) + -- ~ `Step_read_before_table.fill-succ`: `%`(`%;%`_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.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]) - -- 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]) + -- 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) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -11358,48 +17727,48 @@ relation Step_read: `%~>%`(config, 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)]), []) - -- 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)])) - -- ~ `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)]), []) + -- 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)])) + -- ~ `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) ;; ../../../../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)]) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_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, 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)) - -- ~ `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)])) + -- ~ `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) ;; ../../../../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)]) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_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, 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_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))))) + -- 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: `%`(`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)) - -- ~ `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)])) + -- ~ `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)])) ;; ../../../../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]) - -- 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]) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) @@ -11407,127 +17776,127 @@ relation Step_read: `%~>%`(config, 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)]), []) - -- 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)])) - -- ~ `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)]), []) + -- 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)])) + -- ~ `Step_read_before_table.init-zero`: `%`(`%;%`_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 (n = 0) ;; ../../../../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)]) + `%~>%`(`%;%`_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) =/= ?()) - -- 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_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)) - -- ~ `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)])) + -- ~ `Step_read_before_table.init-succ`: `%`(`%;%`_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 `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]) - -- 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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../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)]) - -- 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)]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) -- wf_instr: `%`(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)]) ;; ../../../../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]) - -- 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]) + -- 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) -- 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|) ;; ../../../../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)))]) - -- 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)))]) + -- 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)))) -- 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)]) ;; ../../../../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]) - -- 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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../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)]) - -- 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)]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) -- wf_instr: `%`(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)]) ;; ../../../../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]) - -- 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]) + -- 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) -- 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|) ;; ../../../../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)]) - -- 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)]), [VCONST_instr(V128_vectype, c)]) + -- 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: `%`(VCONST_instr(V128_vectype, c)) - -- wf_shape: `%`(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(K))) - -- (wf_lane_: `%%`($lanetype(`%X%`_shape((Jnn : Jnn <: lanetype), `%`_dim(K))), mk_lane__2_lane_(Jnn, $extend__(M, $jsizenn(Jnn), sx, j))))^K{j <- `j*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(K))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(K))), mk_lane__2_lane_(Jnn, $extend__(M, $jsizenn(Jnn), sx, j))))^K{j <- `j*`} -- (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]) - -- 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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../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)]) - -- 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)]), [VCONST_instr(V128_vectype, c)]) + -- 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))) -- 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{})) + -- if (c = $inv_lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))^M{})) ;; ../../../../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]) - -- 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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) -- wf_instr: `%`(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|) ;; ../../../../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)]) + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)]), [VCONST_instr(V128_vectype, c)]) -- 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_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)) -- 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)]) @@ -11535,65 +17904,66 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../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]) - -- 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]) + -- 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) -- 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|) ;; ../../../../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)]) - -- 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)]), [VCONST_instr(V128_vectype, c)]) + -- 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))) -- 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))])) + -- 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))])) ;; ../../../../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)))]) -- 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)) -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) -- if ($mem(z, x).TYPE_meminst = `%%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]) - -- 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]) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) ;; ../../../../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)]), []) - -- 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)])) - -- ~ `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)]), []) + -- 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)])) + -- ~ `Step_read_before_memory.fill-zero`: `%`(`%;%`_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 (n = 0) ;; ../../../../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)]) + rule `memory.fill-succ`{z : state, at : addrtype, i : num_, val : val, n : n, x : idx, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) 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) =/= ?()) - -- 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_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_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, var_0)) + -- 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)) - -- ~ `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)])) + -- ~ `Step_read_before_memory.fill-succ`: `%`(`%;%`_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)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../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]) - -- 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]) + -- 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) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -11601,48 +17971,50 @@ relation Step_read: `%~>%`(config, 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)]), []) - -- 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)])) - -- ~ `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)]), []) + -- 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)])) + -- ~ `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) ;; ../../../../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)]) + 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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0) 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) =/= ?()) - -- 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_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_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, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) + -- 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)) - -- ~ `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)])) + -- ~ `Step_read_before_memory.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))) `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) + -- fun_memarg0: `%`(var_0) ;; ../../../../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)]) + 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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0) 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) =/= ?()) - -- 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_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_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, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) + -- 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)) - -- ~ `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)])) + -- ~ `Step_read_before_memory.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))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../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]) - -- 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]) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) @@ -11650,26 +18022,27 @@ relation Step_read: `%~>%`(config, 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)]), []) - -- 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)])) - -- ~ `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)]), []) + -- 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)])) + -- ~ `Step_read_before_memory.init-zero`: `%`(`%;%`_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 (n = 0) ;; ../../../../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)]) + rule `memory.init-succ`{z : state, at : addrtype, i : num_, j : num_, n : n, x : idx, y : idx, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) 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) =/= ?()) - -- 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_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)))) - -- 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: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, var_0)) + -- 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)) - -- ~ `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)])) + -- ~ `Step_read_before_memory.init-succ`: `%`(`%;%`_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)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `ref.null`{z : state, ht : heaptype}: @@ -11685,49 +18058,55 @@ relation Step_read: `%~>%`(config, instr*) -- 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, 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)))]) + rule `ref.test-true`{s : store, f : frame, ref : ref, rt : reftype, 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)))]) -- wf_reftype: `%`(rt') - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `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(1)))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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)))]) - -- 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)))]) + -- 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)))) - -- ~ `Step_read_before_ref.test-false`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.TEST`_instr(rt)])) + -- ~ `Step_read_before_ref.test-false`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype}: - `%~>%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)]), [(ref : ref <: instr)]) + rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [$instr_ref(ref)]) -- wf_reftype: `%`(rt') - -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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]) - -- 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]) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) -- wf_instr: `%`(TRAP_instr) - -- ~ `Step_read_before_ref.cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [(ref : ref <: instr) `REF.CAST`_instr(rt)])) + -- ~ `Step_read_before_ref.cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) ;; ../../../../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)]) + rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*, `var_1*` : valtype*, `var_0*` : val??*}: + `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(val)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) -- (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*`}))) -- 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*`} + -- if (|`var_0*`| = |`val*`|) + -- (if (var_0 =/= ?()))*{var_0 <- `var_0*`} + -- (if (!(var_0) = ?(val)))*{var_0 <- `var_0*`, val <- `val*`} + -- if (|`var_1*`| = |`zt*`|) + -- (fun_unpack: `%%`(zt, var_1))*{var_1 <- `var_1*`, zt <- `zt*`} + -- if (|`var_1*`| = |`var_0*`|) + -- (fun_default_: `%%`(var_1, var_0))*{var_1 <- `var_1*`, var_0 <- `var_0*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `struct.get-null`{z : state, `sx?` : sx?, x : idx, i : fieldidx}: @@ -11736,26 +18115,29 @@ relation Step_read: `%~>%`(config, instr*) -- 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*`}[$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)|) + rule `struct.get-struct`{z : state, a : addr, `sx?` : sx?, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*, var_0 : val?}: + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [$instr_val(!(var_0))]) + -- if (var_0 =/= ?()) -- 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*`}))) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) + -- if ($proj_uN_0(i).0 < |$structinst(z)[a].FIELDS_structinst|) + -- if (a < |$structinst(z)|) + -- fun_unpackfield_: `%%%%`(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0], var_0) ;; ../../../../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))]) + rule `array.new_default`{z : state, n : n, x : idx, val : val, `mut?` : mut?, zt : storagetype, var_1 : valtype, var_0 : val??}: + `%~>%`(`%;%`_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))]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($default_($unpack(zt)) =/= ?()) - -- if (!($default_($unpack(zt))) = ?(val)) + -- if (var_0 =/= ?()) + -- if (!(var_0) = ?(val)) + -- fun_unpack: `%%`(zt, var_1) + -- fun_default_: `%%`(var_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.new_elem-oob`{z : state, i : num_, n : n, x : idx, y : idx}: @@ -11767,7 +18149,7 @@ relation Step_read: `%~>%`(config, 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))]) + `%~>%`(`%;%`_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))]) -- (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))) @@ -11775,28 +18157,33 @@ relation Step_read: `%~>%`(config, instr*) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : 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}: + rule `array.new_data-oob`{z : state, i : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: `%~>%`(`%;%`_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]) -- 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))) -- 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|) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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{} + rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?, var_3 : nat?, `var_2*` : lit_*, var_1 : consttype?, `var_0*` : 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)]), var_0^n{var_0 <- `var_0*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- (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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($zsize(zt) =/= ?()) + -- if (var_3 =/= ?()) -- 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)]) + -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !(var_3)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- fun_zsize: `%%`(zt, var_3) + -- (fun_cunpacknum_: `%%%`(zt, c, var_2))^n{var_2 <- `var_2*`, c <- `c*`} + -- fun_cunpack: `%%`(zt, var_1) + -- (if (var_1 =/= ?()))^n{} + -- (fun_const: `%%%`(!(var_1), var_2, var_0))^n{var_2 <- `var_2*`, var_0 <- `var_0*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -11814,15 +18201,16 @@ relation Step_read: `%~>%`(config, instr*) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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) =/= ?()) + rule `array.get-array`{z : state, a : addr, i : num_, `sx?` : sx?, x : idx, zt : storagetype, `mut?` : mut?, var_0 : val?}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [$instr_val(!(var_0))]) + -- if (var_0 =/= ?()) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (a < |$arrayinst(z)|) + -- if ($proj_num__0(i) =/= ?()) + -- fun_unpackfield_: `%%%%`(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.len-null`{z : state}: @@ -11839,14 +18227,14 @@ relation Step_read: `%~>%`(config, instr*) ;; ../../../../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]) - -- 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]) + -- 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) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) @@ -11854,34 +18242,34 @@ relation Step_read: `%~>%`(config, 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)]), []) - -- 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)])) - -- ~ `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)]), []) + -- 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)])) + -- ~ `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) ;; ../../../../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)]) + `%~>%`(`%;%`_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) =/= ?()) - -- 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)])) -- 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((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) -- wf_instr: `%`(`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)])) + -- ~ `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)])) ;; ../../../../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 @@ -11910,7 +18298,7 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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}: + 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, var_0 : sx??}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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) =/= ?()) @@ -11928,11 +18316,12 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 ($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 (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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}: + 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, var_0 : sx??}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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) =/= ?()) @@ -11950,8 +18339,9 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 (var_0 =/= ?()) + -- if (sx?{sx <- `sx?`} = !(var_0)) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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}: @@ -11985,7 +18375,7 @@ 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_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)]) + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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) =/= ?()) -- wf_ref: `%`(ref) @@ -12017,15 +18407,16 @@ relation Step_read: `%~>%`(config, instr*) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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}: + rule `array.init_data-oob2`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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.ARRAY_ADDR`_instr(a) 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))) -- 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|) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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}: @@ -12035,25 +18426,29 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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) =/= ?()) + 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?, var_3 : nat?, var_2 : lit_, var_1 : consttype?, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 + (((!(var_3) : 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 ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) + -- if (var_3 =/= ?()) -- 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_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(($proj_uN_0(!($proj_num__0(j))).0 + (((!(var_3) : 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))) -- ~ `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 ($zbytes_(zt, c) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- fun_zsize: `%%`(zt, var_3) + -- fun_cunpacknum_: `%%%`(zt, c, var_2) + -- fun_cunpack: `%%`(zt, var_1) + -- if (var_1 =/= ?()) + -- fun_const: `%%%`(!(var_1), var_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rec { @@ -12076,9 +18471,9 @@ 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*`})) - -- 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*`})) + `%~>%`(`%;%`_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*`})) + -- 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'*`})) -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', instr'*{instr' <- `instr'*`})) @@ -12112,219 +18507,244 @@ relation Step: `%~>%`(config, config) -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr*{instr <- `instr*`}), `%;%`_config(`%;%`_state(s', f''), instr'*{instr' <- `instr'*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:231.1-235.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])) - -- 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])) + rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_1 : deftype?, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- 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 (var_1 =/= ?()) + -- Expand: `%~~%`(!(var_1), `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*`}}) + -- fun_as_deftype: `%%`($tag(z, x).TYPE_taginst, var_1) + -- fun_add_exninst: `%%%`(z, [exn], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:309.1-310.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), [])) + rule `local.set`{z : state, val : val, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_local: `%%%%`(z, x, val, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:322.1-323.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), [])) + rule `global.set`{z : state, val : val, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_global: `%%%%`(z, x, val, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.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])) - -- 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])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:340.1-342.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), [])) + rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- if ($proj_num__0(i) =/= ?()) - -- 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), [])) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- fun_with_table: `%%%%%`(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:351.1-354.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|)))])) - -- 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|)))])) - -- if ($growtable($table(z, x), n, ref) =/= ?()) - -- if (ti = !($growtable($table(z, x), n, ref))) + rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst, var_1 : tableinst?, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- 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(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- if (var_1 =/= ?()) + -- if (ti = !(var_1)) + -- fun_growtable: `%%%%`($table(z, x), n, ref, var_1) + -- fun_with_tableinst: `%%%%`(z, x, ti, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:356.1-357.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:417.1-418.51 - rule `elem.drop`{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config($with_elem(z, x, []), [])) + rule `elem.drop`{z : state, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_elem(z, x, []), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_elem: `%%%%`(z, x, [], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:501.1-504.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])) - -- 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])) + -- 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) =/= ?()) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:506.1-510.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) =/= ?()) - -- 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*`}), [])) + rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:512.1-515.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])) - -- 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])) + -- 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])) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:517.1-521.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) =/= ?()) - -- 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*`}), [])) + rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_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(var_0, [])) + -- 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(var_0, [])) -- if ($proj_num__0(c) =/= ?()) - -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size((Inn : addrtype <: numtype)), n, !($proj_num__0(c))))) + -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:523.1-526.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])) - -- 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])) + -- 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) =/= ?()) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:528.1-531.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) =/= ?()) - -- 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*`}), [])) + rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:534.1-537.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])) - -- 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])) + -- 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])) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:539.1-544.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) =/= ?()) - -- 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*`}), [])) - -- 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)|) - -- 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)) + 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, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(var_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(var_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_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) -- 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))) + -- 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_num__0(i) =/= ?()) + -- fun_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*`}, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:553.1-556.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))))])) - -- 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))))])) - -- if ($growmem($mem(z, x), n) =/= ?()) - -- if (mi = !($growmem($mem(z, x), n))) + rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst, var_1 : meminst?, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [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 (var_1 =/= ?()) + -- if (mi = !(var_1)) + -- fun_growmem: `%%%`($mem(z, x), n, var_1) + -- fun_with_meminst: `%%%%`(z, x, mi, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:558.1-559.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:619.1-620.51 - rule `data.drop`{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config($with_data(z, x, []), [])) + rule `data.drop`{z : state, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [`DATA.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_data(z, x, []), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_data: `%%%%`(z, x, [], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:700.1-704.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)])) - -- 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)])) + rule `struct.new`{z : state, n : n, `val*` : val*, x : idx, si : structinst, a : addr, `mut?*` : mut?*, `zt*` : storagetype*, `var_1*` : fieldval?*, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config(var_0, [`REF.STRUCT_ADDR`_instr(a)])) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [`REF.STRUCT_ADDR`_instr(a)])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`, zt <- `zt*`} - -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`, zt <- `zt*`}}) + -- (if (var_1 =/= ?()))^n{var_1 <- `var_1*`} + -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}}) -- 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*`}}) + -- if (si = {TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}}) + -- (fun_packfield_: `%%%`(zt, val, var_1))^n{var_1 <- `var_1*`, val <- `val*`, zt <- `zt*`} + -- fun_add_structinst: `%%%`(z, [si], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:721.1-722.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:724.1-727.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*`}|) - -- 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))), [])) + rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*, var_1 : fieldval?, var_0 : state}: + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) + -- fun_packfield_: `%%%`(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val, var_1) + -- if (var_1 =/= ?()) + -- fun_with_struct: `%%%%%`(z, a, $proj_uN_0(i).0, !(var_1), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:740.1-745.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)])) - -- 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)])) + rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype, `var_1*` : fieldval?*, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config(var_0, [`REF.ARRAY_ADDR`_instr(a)])) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) + -- wf_config: `%`(`%;%`_config(var_0, [`REF.ARRAY_ADDR`_instr(a)])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- (if ($packfield_(zt, val) =/= ?()))^n{val <- `val*`} - -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !($packfield_(zt, val))^n{val <- `val*`}}) + -- (if (var_1 =/= ?()))^n{var_1 <- `var_1*`} + -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}}) -- 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*`}})) + -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}})) + -- (fun_packfield_: `%%%`(zt, val, var_1))^n{var_1 <- `var_1*`, val <- `val*`} + -- fun_add_arrayinst: `%%%`(z, [ai], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:785.1-786.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:788.1-790.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])) - -- 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])) + -- 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])) -- if ($proj_num__0(i) =/= ?()) -- if (a < |$arrayinst(z)|) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:792.1-795.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) =/= ?()) - -- 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))), [])) + rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?, var_1 : fieldval?, var_0 : state}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- fun_packfield_: `%%%`(zt, val, var_1) + -- if ($proj_num__0(i) =/= ?()) + -- if (var_1 =/= ?()) + -- fun_with_array: `%%%%%`(z, a, $proj_uN_0(!($proj_num__0(i))).0, !(var_1), var_0) } ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -12353,29 +18773,36 @@ relation Eval_expr: `%;%~>*%;%`(state, expr, state, val*) rule _{z : state, `instr*` : instr*, z' : state, `val*` : val*}: `%;%~>*%;%`(z, instr*{instr <- `instr*`}, z', val*{val <- `val*`}) -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) - -- wf_config: `%`(`%;%`_config(z', (val : val <: instr)*{val <- `val*`})) - -- Steps: `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', (val : val <: instr)*{val <- `val*`})) + -- wf_config: `%`(`%;%`_config(z', $instr_val(val)*{val <- `val*`})) + -- Steps: `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_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*, `deftype*` : deftype*, rectype : rectype, x : uN}(type'*{type' <- `type'*`} ++ [type]) = deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`} +;; ../../../../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*, `deftype*` : deftype*, rectype : rectype, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: + `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) + -- 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) -- wf_uN: `%%`(32, x) - -- if (deftype'*{deftype' <- `deftype'*`} = $alloctypes(type'*{type' <- `type'*`})) + -- if (deftype'#1*{deftype'#1 <- `deftype'*`} = var_0) -- if (type = TYPE_type(rectype)) - -- 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'*`}|) } ;; ../../../../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|)) -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE tagtype}) -- if (taginst = {TYPE tagtype}) @@ -12383,22 +18810,28 @@ def $alloctag(store : store, tagtype : tagtype) : (store, tagaddr) ;; ../../../../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_2 : store, ja : nat, `ja'*` : tagaddr*, s_1 : store}(s, [tagtype] ++ tagtype'*{tagtype' <- `tagtype'*`}) = (s_2, [ja] ++ ja'*{ja' <- `ja'*`}) +;; ../../../../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*, s_2 : store, ja : nat, `ja'*` : tagaddr*, s_1 : store, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: + `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) + -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) + -- fun_alloctag: `%%%`(s, tagtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ja) = $alloctag(s, tagtype)) - -- if ((s_2, ja'*{ja' <- `ja'*`}) = $alloctags(s_1, tagtype'*{tagtype' <- `tagtype'*`})) + -- if ((s_1, ja) = var_0) + -- if ((s_2, ja'#1*{ja'#1 <- `ja'*`}) = 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|)) -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) -- if (globalinst = {TYPE globaltype, VALUE val}) @@ -12406,68 +18839,86 @@ def $allocglobal(store : store, globaltype : globaltype, val : val) : (store, gl ;; ../../../../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_2 : store, ga : nat, `ga'*` : globaladdr*, s_1 : store}(s, [globaltype] ++ globaltype'*{globaltype' <- `globaltype'*`}, [val] ++ val'*{val' <- `val'*`}) = (s_2, [ga] ++ ga'*{ga' <- `ga'*`}) +;; ../../../../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*, s_2 : store, ga : nat, `ga'*` : globaladdr*, s_1 : store, 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'*`})) + -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ga) = $allocglobal(s, globaltype, val)) - -- if ((s_2, ga'*{ga' <- `ga'*`}) = $allocglobals(s_1, globaltype'*{globaltype' <- `globaltype'*`}, val'*{val' <- `val'*`})) + -- if ((s_1, ga) = var_0) + -- if ((s_2, ga'#1*{ga'#1 <- `ga'*`}) = var_1) } ;; ../../../../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?{j <- `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|)) -- 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)){}}) - -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j?{j <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#12?{j#12 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + -- if (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 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_2 : store, ma : nat, `ma'*` : memaddr*, s_1 : store}(s, [memtype] ++ memtype'*{memtype' <- `memtype'*`}) = (s_2, [ma] ++ ma'*{ma' <- `ma'*`}) +;; ../../../../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*, s_2 : store, ma : nat, `ma'*` : memaddr*, s_1 : store, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: + `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) + -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) + -- fun_allocmem: `%%%`(s, memtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ma) = $allocmem(s, memtype)) - -- if ((s_2, ma'*{ma' <- `ma'*`}) = $allocmems(s_1, memtype'*{memtype' <- `memtype'*`})) + -- if ((s_1, ma) = var_0) + -- if ((s_2, ma'#1*{ma'#1 <- `ma'*`}) = 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 - 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|) + 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|)) -- 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{}}) - -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j?{j <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#15?{j#15 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) + -- if (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 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_2 : store, ta : nat, `ta'*` : tableaddr*, s_1 : store}(s, [tabletype] ++ tabletype'*{tabletype' <- `tabletype'*`}, [ref] ++ ref'*{ref' <- `ref'*`}) = (s_2, [ta] ++ ta'*{ta' <- `ta'*`}) +;; ../../../../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*, s_2 : store, ta : nat, `ta'*` : tableaddr*, s_1 : store, 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'*`})) + -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) + -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ta) = $alloctable(s, tabletype, ref)) - -- if ((s_2, ta'*{ta' <- `ta'*`}) = $alloctables(s_1, tabletype'*{tabletype' <- `tabletype'*`}, ref'*{ref' <- `ref'*`})) + -- if ((s_1, ta) = var_0) + -- if ((s_2, ta'#1*{ta'#1 <- `ta'*`}) = var_1) } ;; ../../../../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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) -- if (funcinst = {TYPE deftype, MODULE moduleinst, CODE funccode}) @@ -12475,91 +18926,146 @@ def $allocfunc(store : store, deftype : deftype, funccode : funccode, moduleinst ;; ../../../../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_2 : store, fa : nat, `fa'*` : funcaddr*, s_1 : store}(s, [dt] ++ dt'*{dt' <- `dt'*`}, [funccode] ++ funccode'*{funccode' <- `funccode'*`}, [moduleinst] ++ moduleinst'*{moduleinst' <- `moduleinst'*`}) = (s_2, [fa] ++ fa'*{fa' <- `fa'*`}) +;; ../../../../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*, s_2 : store, fa : nat, `fa'*` : funcaddr*, s_1 : store, 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'*`})) + -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, fa) = $allocfunc(s, dt, funccode, moduleinst)) - -- if ((s_2, fa'*{fa' <- `fa'*`}) = $allocfuncs(s_1, dt'*{dt' <- `dt'*`}, funccode'*{funccode' <- `funccode'*`}, moduleinst'*{moduleinst' <- `moduleinst'*`})) + -- if ((s_1, fa) = var_0) + -- if ((s_2, fa'#1*{fa'#1 <- `fa'*`}) = var_1) } ;; ../../../../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 - 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|) + 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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_datainst: `%`({BYTES byte*{byte <- `byte*`}}) - -- if (datainst = {BYTES byte*{byte <- `byte*`}}) + -- wf_datainst: `%`({BYTES byte#3*{byte#3 <- `byte*`}}) + -- if (datainst = {BYTES byte#4*{byte#4 <- `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_2 : store, da : nat, `da'*` : dataaddr*, s_1 : store}(s, [ok] ++ ok'*{ok' <- `ok'*`}, [b*{b <- `b*`}] ++ b'*{b' <- `b'*`}*{`b'*` <- `b'**`}) = (s_2, [da] ++ da'*{da' <- `da'*`}) +;; ../../../../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**, s_2 : store, da : nat, `da'*` : dataaddr*, s_1 : store, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: + `%%%%`(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'*`})) + -- 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#11*{b#11 <- `b*`}, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, da) = $allocdata(s, ok, b*{b <- `b*`})) - -- if ((s_2, da'*{da' <- `da'*`}) = $allocdatas(s_1, ok'*{ok' <- `ok'*`}, b'*{b' <- `b'*`}*{`b'*` <- `b'**`})) + -- if ((s_1, da) = var_0) + -- if ((s_2, da'#1*{da'#1 <- `da'*`}) = var_1) } ;; ../../../../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*{ref <- `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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) - -- wf_eleminst: `%`({TYPE elemtype, REFS ref*{ref <- `ref*`}}) - -- if (eleminst = {TYPE elemtype, REFS ref*{ref <- `ref*`}}) + -- wf_eleminst: `%`({TYPE elemtype, REFS ref#2*{ref#2 <- `ref*`}}) + -- if (eleminst = {TYPE elemtype, REFS ref#3*{ref#3 <- `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_2 : store, ea : nat, `ea'*` : elemaddr*, s_1 : store}(s, [rt] ++ rt'*{rt' <- `rt'*`}, [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) = (s_2, [ea] ++ ea'*{ea' <- `ea'*`}) +;; ../../../../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**, s_2 : store, ea : nat, `ea'*` : elemaddr*, s_1 : store, 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'*`})) + -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ea) = $allocelem(s, rt, ref*{ref <- `ref*`})) - -- if ((s_2, ea'*{ea' <- `ea'*`}) = $allocelems(s_1, rt'*{rt' <- `rt'*`}, ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`})) + -- if ((s_1, ea) = var_0) + -- if ((s_2, ea'#1*{ea'#1 <- `ea'*`}) = var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocexport(moduleinst : moduleinst, export : export) : exportinst +relation fun_allocexport: `%%%`(moduleinst, 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])} + rule fun_allocexport_case_0{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.TAGS_moduleinst|) -- 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])} + rule fun_allocexport_case_1{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.GLOBALS_moduleinst|) -- 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])} + rule fun_allocexport_case_2{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.MEMS_moduleinst|) -- 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])} + rule fun_allocexport_case_3{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.TABLES_moduleinst|) -- 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])} + rule fun_allocexport_case_4{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.FUNCS_moduleinst|) -- wf_exportinst: `%`({NAME name, ADDR FUNC_externaddr(moduleinst.FUNCS_moduleinst[$proj_uN_0(x).0])}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocexports(moduleinst : moduleinst, export*) : exportinst* +relation fun_allocexports: `%%%`(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*`} + rule fun_allocexports_case_0{moduleinst : moduleinst, `export*` : export*, `var_0*` : exportinst*}: + `%%%`(moduleinst, export#4*{export#4 <- `export*`}, var_0*{var_0 <- `var_0*`}) + -- if (|`var_0*`| = |`export*`|) + -- (fun_allocexport: `%%%`(moduleinst, export, var_0))*{var_0 <- `var_0*`, export <- `export*`} ;; ../../../../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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `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) + 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_13 : exportinst*, var_12 : (store, funcaddr*), `var_11*` : elemtype*, var_10 : (store, elemaddr*), var_9 : (store, dataaddr*), `var_8*` : tabletype*, var_7 : (store, tableaddr*), `var_6*` : memtype*, var_5 : (store, memaddr*), `var_4*` : globaltype*, var_3 : (store, globaladdr*), `var_2*` : tagtype*, var_1 : (store, tagaddr*), var_0 : deftype*}: + `%%%%%%%`(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)) + -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_13) + -- (if ($proj_uN_0(x#4).0 < |dt#15*{dt#15 <- `dt*`}|))*{x#4 <- `x*`} + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_12) + -- if (|`var_11*`| = |`elemtype*`|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_11))*{var_11 <- `var_11*`, elemtype#3 <- `elemtype*`} + -- fun_allocelems: `%%%%`(s_5, var_11*{var_11 <- `var_11*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_10) + -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_9) + -- if (|`var_8*`| = |`tabletype*`|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_8))*{var_8 <- `var_8*`, tabletype#160 <- `tabletype*`} + -- fun_alloctables: `%%%%`(s_3, var_8*{var_8 <- `var_8*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_7) + -- if (|`var_6*`| = |`memtype*`|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_6))*{var_6 <- `var_6*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_6*{var_6 <- `var_6*`}, var_5) + -- if (|`var_4*`| = |`globaltype*`|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_4))*{var_4 <- `var_4*`, globaltype#126 <- `globaltype*`} + -- fun_allocglobals: `%%%%`(s_1, var_4*{var_4 <- `var_4*`}, val_G#2*{val_G#2 <- `val_G*`}, var_3) + -- if (|`var_2*`| = |`tagtype*`|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_2))*{var_2 <- `var_2*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_2*{var_2 <- `var_2*`}, var_1) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `type*`}, var_0) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(moduleinst) -- wf_store: `%`(s_1) @@ -12568,61 +19074,76 @@ def $allocmodule(store : store, module : module, externaddr*, val*, ref*, ref**) -- wf_store: `%`(s_4) -- wf_store: `%`(s_5) -- wf_store: `%`(s_6) - -- 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*`}}) - -- if (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*`}))) - -- 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**`}) - -- if (aa_I*{aa_I <- `aa_I*`} = $tagsxa(externaddr*{externaddr <- `externaddr*`})) - -- if (ga_I*{ga_I <- `ga_I*`} = $globalsxa(externaddr*{externaddr <- `externaddr*`})) - -- if (ma_I*{ma_I <- `ma_I*`} = $memsxa(externaddr*{externaddr <- `externaddr*`})) - -- if (ta_I*{ta_I <- `ta_I*`} = $tablesxa(externaddr*{externaddr <- `externaddr*`})) - -- if (fa_I*{fa_I <- `fa_I*`} = $funcsxa(externaddr*{externaddr <- `externaddr*`})) - -- if (dt*{dt <- `dt*`} = $alloctypes(type*{type <- `type*`})) - -- if (fa*{fa <- `fa*`} = (|s.FUNCS_store| + i_F)^(i_F<|func*{func <- `func*`}|){}) - -- if ((s_1, aa*{aa <- `aa*`}) = $alloctags(s, $subst_all_tagtype(tagtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{tagtype <- `tagtype*`})) - -- if ((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*`})) - -- if ((s_3, ma*{ma <- `ma*`}) = $allocmems(s_2, $subst_all_memtype(memtype, (dt : deftype <: typeuse)*{dt <- `dt*`})*{memtype <- `memtype*`})) - -- if ((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*`})) - -- if ((s_5, da*{da <- `da*`}) = $allocdatas(s_4, OK_datatype^|data*{data <- `data*`}|{}, byte*{byte <- `byte*`}*{`byte*` <- `byte**`})) - -- if ((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_module: `%`(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*`}))) + -- (wf_tag: `%`(TAG_tag(tagtype#78)))*{tagtype#78 <- `tagtype*`} + -- if (|`expr_G*`| = |`globaltype*`|) + -- (wf_global: `%`(GLOBAL_global(globaltype#122, expr_G#1)))*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`} + -- (wf_mem: `%`(MEMORY_mem(memtype#122)))*{memtype#122 <- `memtype*`} + -- if (|`expr_T*`| = |`tabletype*`|) + -- (wf_table: `%`(TABLE_table(tabletype#156, expr_T#1)))*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`} + -- if (|`expr_F*`| = |`local**`|) + -- if (|`expr_F*`| = |`x*`|) + -- (wf_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 (|`byte**`| = |`datamode*`|) + -- (wf_data: `%`(DATA_data(byte#5*{byte#5 <- `byte*#110`}, datamode#110)))*{`byte*#110` <- `byte**`, datamode#110 <- `datamode*`} + -- if (|`elemmode*`| = |`elemtype*`|) + -- if (|`elemmode*`| = |`expr_E**`|) + -- (wf_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**`} + -- wf_moduleinst: `%`({TYPES [], TAGS aa_I#1*{aa_I#1 <- `aa_I*`} ++ aa#1*{aa#1 <- `aa*`}, GLOBALS ga_I#1*{ga_I#1 <- `ga_I*`} ++ ga#1*{ga#1 <- `ga*`}, MEMS ma_I#1*{ma_I#1 <- `ma_I*`} ++ ma#1*{ma#1 <- `ma*`}, TABLES ta_I#1*{ta_I#1 <- `ta_I*`} ++ ta#1*{ta#1 <- `ta*`}, FUNCS fa_I#1*{fa_I#1 <- `fa_I*`} ++ fa#1*{fa#1 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({TYPES dt#8*{dt#8 <- `dt*`}, 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#2*{fa#2 <- `fa*`}, DATAS da#1*{da#1 <- `da*`}, ELEMS ea#1*{ea#1 <- `ea*`}, EXPORTS xi#1*{xi#1 <- `xi*`}}) + -- if (module = MODULE_module(`%`_list(type#3*{type#3 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#3*{tag#3 <- `tag*`}), `%`_list(global#5*{global#5 <- `global*`}), `%`_list(mem#5*{mem#5 <- `mem*`}), `%`_list(table#5*{table#5 <- `table*`}), `%`_list(func#4*{func#4 <- `func*`}), `%`_list(data#3*{data#3 <- `data*`}), `%`_list(elem#5*{elem#5 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#6*{export#6 <- `export*`}))) + -- if (tag#4*{tag#4 <- `tag*`} = TAG_tag(tagtype#80)*{tagtype#80 <- `tagtype*`}) + -- if (global#6*{global#6 <- `global*`} = GLOBAL_global(globaltype#124, expr_G#2)*{expr_G#2 <- `expr_G*`, globaltype#124 <- `globaltype*`}) + -- if (mem#6*{mem#6 <- `mem*`} = MEMORY_mem(memtype#124)*{memtype#124 <- `memtype*`}) + -- if (table#6*{table#6 <- `table*`} = TABLE_table(tabletype#158, expr_T#2)*{expr_T#2 <- `expr_T*`, tabletype#158 <- `tabletype*`}) + -- if (func#5*{func#5 <- `func*`} = FUNC_func(x#3, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#3 <- `x*`}) + -- if (data#4*{data#4 <- `data*`} = DATA_data(byte#6*{byte#6 <- `byte*#112`}, datamode#112)*{`byte*#112` <- `byte**`, datamode#112 <- `datamode*`}) + -- if (elem#6*{elem#6 <- `elem*`} = ELEM_elem(elemtype#2, expr_E#2*{expr_E#2 <- `expr_E*#2`}, elemmode#232)*{elemmode#232 <- `elemmode*`, elemtype#2 <- `elemtype*`, `expr_E*#2` <- `expr_E**`}) + -- if (aa_I#3*{aa_I#3 <- `aa_I*`} = $tagsxa(externaddr#2*{externaddr#2 <- `externaddr*`})) + -- if (ga_I#3*{ga_I#3 <- `ga_I*`} = $globalsxa(externaddr#3*{externaddr#3 <- `externaddr*`})) + -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`})) + -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = $tablesxa(externaddr#5*{externaddr#5 <- `externaddr*`})) + -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = $funcsxa(externaddr#6*{externaddr#6 <- `externaddr*`})) + -- if (dt#9*{dt#9 <- `dt*`} = var_0) + -- if (fa#3*{fa#3 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#6*{func#6 <- `func*`}|){}) + -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_1) + -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_3) + -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_5) + -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_7) + -- if ((s_5, da#2*{da#2 <- `da*`}) = var_9) + -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_10) + -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_12) + -- if (xi#2*{xi#2 <- `xi*`} = var_13) + -- if (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 -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^n{b <- `b*`}, PASSIVE_datamode)) = [] + rule fun_rundata__case_0{x : uN, n : nat, `b*` : byte*}: + `%%%`(x, DATA_data(b#12^n{b#12 <- `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)] + rule fun_rundata__case_1{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)) ;; ../../../../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^n{e <- `e*`}, PASSIVE_elemmode)) = [] + rule fun_runelem__case_0{x : uN, rt : reftype, n : nat, `e*` : expr*}: + `%%%`(x, ELEM_elem(rt, e#1^n{e#1 <- `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)] + rule fun_runelem__case_1{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)) + ;; ../../../../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)] + rule fun_runelem__case_2{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)) @@ -12631,110 +19152,144 @@ def $runelem_(elemidx : elemidx, elem : elem) : instr* ;; ../../../../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*, z'' : state, ref : ref, `ref'*` : ref*, z' : state}(z, [expr] ++ expr'*{expr' <- `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*, z'' : state, ref : ref, `ref'*` : ref*, z' : state, var_0 : (state, ref*)}: + `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) -- wf_state: `%`(z'') -- wf_ref: `%`(ref) - -- (wf_ref: `%`(ref'))*{ref' <- `ref'*`} + -- (wf_ref: `%`(ref'#5))*{ref'#5 <- `ref'*`} -- wf_state: `%`(z') - -- Eval_expr: `%;%~>*%;%`(z, expr, z', [(ref : ref <: val)]) - -- if ((z'', ref'*{ref' <- `ref'*`}) = $evalexprs(z', expr'*{expr' <- `expr'*`})) + -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) + -- if ((z'', ref'#6*{ref'#6 <- `ref'*`}) = 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'' : state, `ref*` : ref*, `ref'**` : ref**, z' : state}(z, [expr*{expr <- `expr*`}] ++ expr'*{expr' <- `expr'*`}*{`expr'*` <- `expr'**`}) = (z'', [ref*{ref <- `ref*`}] ++ ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) +;; ../../../../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**, z'' : state, `ref*` : ref*, `ref'**` : ref**, z' : state, 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'**`})) + -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) + -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) -- wf_state: `%`(z'') - -- (wf_ref: `%`(ref))*{ref <- `ref*`} - -- (wf_ref: `%`(ref'))*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`} + -- (wf_ref: `%`(ref#6))*{ref#6 <- `ref*`} + -- (wf_ref: `%`(ref'#7))*{ref'#7 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`} -- wf_state: `%`(z') - -- if ((z', ref*{ref <- `ref*`}) = $evalexprs(z, expr*{expr <- `expr*`})) - -- if ((z'', ref'*{ref' <- `ref'*`}*{`ref'*` <- `ref'**`}) = $evalexprss(z', expr'*{expr' <- `expr'*`}*{`expr'*` <- `expr'**`})) + -- if ((z', ref#7*{ref#7 <- `ref*`}) = var_0) + -- if ((z'', ref'#8*{ref'#8 <- `ref'*#4`}*{`ref'*#4` <- `ref'**`}) = 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*, z'' : state, val : val, `val'*` : val*, z' : state, s : store, f : frame, s' : store, a : nat}(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*, z'' : state, val : val, `val'*` : val*, z' : state, s : store, f : frame, s' : store, a : nat, 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'*`})) + -- 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) -- wf_state: `%`(z'') -- wf_val: `%`(val) - -- (wf_val: `%`(val'))*{val' <- `val'*`} + -- (wf_val: `%`(val'#3))*{val'#3 <- `val'*`} -- wf_state: `%`(z') -- wf_state: `%`(`%;%`_state(s, f)) -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) -- Eval_expr: `%;%~>*%;%`(z, expr, z', [val]) -- if (z' = `%;%`_state(s, f)) - -- if ((s', a) = $allocglobal(s, gt, val)) - -- if ((z'', val'*{val' <- `val'*`}) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'*{gt' <- `gt'*`}, expr'*{expr' <- `expr'*`})) + -- if ((s', a) = var_0) + -- if ((z'', val'#4*{val'#4 <- `val'*`}) = var_1) } ;; ../../../../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*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, 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?`})) + rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_7*` : instr**, `var_6*` : instr**, var_5 : (store, moduleinst), var_4 : (state, ref**), var_3 : (state, ref*), var_2 : (state, val*), var_1 : deftype*, 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?`}))) + -- (if (i_E#2 < |elem#12*{elem#12 <- `elem*`}|))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_7))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`} + -- (if (i_D#2 < |data#11*{data#11 <- `data*`}|))^(i_D#2<|data#10*{data#10 <- `data*`}|){} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_6))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_5) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_4) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_3) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_2) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') - -- (wf_val: `%`(val_G))*{val_G <- `val_G*`} + -- (wf_val: `%`(val_G#3))*{val_G#3 <- `val_G*`} -- wf_state: `%`(z'') - -- (wf_ref: `%`(ref_T))*{ref_T <- `ref_T*`} + -- (wf_ref: `%`(ref_T#3))*{ref_T#3 <- `ref_T*`} -- wf_state: `%`(z''') - -- (wf_ref: `%`(ref_E))*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`} - -- 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_ref: `%`(ref_E#3))*{ref_E#3 <- `ref_E*#3`}*{`ref_E*#3` <- `ref_E**`} + -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E#1*{instr_E#1 <- `instr_E*`} ++ instr_D#1*{instr_D#1 <- `instr_D*`} ++ lift(instr_S#1?{instr_S#1 <- `instr_S?`}))) + -- wf_moduletype: `%`(`%->%`_moduletype(xt_I#1*{xt_I#1 <- `xt_I*`}, xt_E#1*{xt_E#1 <- `xt_E*`})) + -- wf_module: `%`(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*`}))) + -- if (|`expr_G*`| = |`globaltype*`|) + -- (wf_global: `%`(GLOBAL_global(globaltype#127, expr_G#3)))*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`} + -- if (|`expr_T*`| = |`tabletype*`|) + -- (wf_table: `%`(TABLE_table(tabletype#161, expr_T#3)))*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`} + -- if (|`byte**`| = |`datamode*`|) + -- (wf_data: `%`(DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)))*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`} + -- if (|`elemmode*`| = |`expr_E**`|) + -- if (|`elemmode*`| = |`reftype*`|) + -- (wf_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*`} + -- (wf_start: `%`(START_start(x#6)))?{x#6 <- `x?`} + -- wf_moduleinst: `%`({TYPES var_0, TAGS [], GLOBALS $globalsxa(externaddr#8*{externaddr#8 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#9*{externaddr#9 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `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?`} - -- 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*`} - -- if (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*`}))) - -- 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 []}) + -- (wf_uN: `%%`(32, `%`_uN(i_D#1)))^(i_D#1<|data#7*{data#7 <- `data*`}|){} + -- (wf_uN: `%%`(32, `%`_uN(i_E#1)))^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){} + -- (wf_instr: `%`(CALL_instr(x#7)))?{x#7 <- `x?`} + -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I#2*{xt_I#2 <- `xt_I*`}, xt_E#2*{xt_E#2 <- `xt_E*`})) + -- if (|`externaddr*`| = |`xt_I*`|) + -- (Externaddr_ok: `%|-%:%`(s, externaddr#10, xt_I#3))*{externaddr#10 <- `externaddr*`, xt_I#3 <- `xt_I*`} + -- if (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#8*{mem#8 <- `mem*`}), `%`_list(table#8*{table#8 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#8*{data#8 <- `data*`}), `%`_list(elem#9*{elem#9 <- `elem*`}), start#7?{start#7 <- `start?`}, `%`_list(export#9*{export#9 <- `export*`}))) + -- if (global#9*{global#9 <- `global*`} = GLOBAL_global(globaltype#129, expr_G#4)*{expr_G#4 <- `expr_G*`, globaltype#129 <- `globaltype*`}) + -- if (table#9*{table#9 <- `table*`} = TABLE_table(tabletype#163, expr_T#4)*{expr_T#4 <- `expr_T*`, tabletype#163 <- `tabletype*`}) + -- if (data#9*{data#9 <- `data*`} = DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`}) + -- if (elem#10*{elem#10 <- `elem*`} = ELEM_elem(reftype#519, expr_E#4*{expr_E#4 <- `expr_E*#4`}, elemmode#239)*{elemmode#239 <- `elemmode*`, `expr_E*#4` <- `expr_E**`, reftype#519 <- `reftype*`}) + -- if (start#8?{start#8 <- `start?`} = START_start(x#8)?{x#8 <- `x?`}) + -- if (moduleinst_0 = {TYPES var_1, TAGS [], GLOBALS $globalsxa(externaddr#11*{externaddr#11 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#12*{externaddr#12 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- if ((z', val_G*{val_G <- `val_G*`}) = $evalglobals(z, globaltype*{globaltype <- `globaltype*`}, expr_G*{expr_G <- `expr_G*`})) - -- if ((z'', ref_T*{ref_T <- `ref_T*`}) = $evalexprs(z', expr_T*{expr_T <- `expr_T*`})) - -- if ((z''', ref_E*{ref_E <- `ref_E*`}*{`ref_E*` <- `ref_E**`}) = $evalexprss(z'', expr_E*{expr_E <- `expr_E*`}*{`expr_E*` <- `expr_E**`})) + -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_2) + -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_3) + -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_4) -- if (z''' = `%;%`_state(s''', f)) - -- if ((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**`})) - -- if (instr_D*{instr_D <- `instr_D*`} = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D), data*{data <- `data*`}[i_D])^(i_D<|data*{data <- `data*`}|){})) - -- if (instr_E*{instr_E <- `instr_E*`} = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E), elem*{elem <- `elem*`}[i_E])^(i_E<|elem*{elem <- `elem*`}|){})) - -- if (instr_S?{instr_S <- `instr_S?`} = CALL_instr(x)?{x <- `x?`}) + -- if ((s'''', moduleinst) = var_5) + -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_6^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`})) + -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_7^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`})) + -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $invoke(store : store, funcaddr : funcaddr, val*) : config +relation fun_invoke: `%%%%`(store, 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))]) - -- 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*`}))) - -- 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*`} + 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))])) + -- if (funcaddr < |s.FUNCS_store|) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val#2)*{val#2 <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))])) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#6*{t_2#6 <- `t_2*`}))) + -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#7*{t_1#7 <- `t_1*`}), `%`_resulttype(t_2#7*{t_2#7 <- `t_2*`}))) + -- if (|`t_1*`| = |`val*`|) + -- (Val_ok: `%|-%:%`(s, val#3, t_1#8))*{t_1#8 <- `t_1*`, val#3 <- `val*`} ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec syntax castop = (null?, null?) @@ -12794,13 +19349,17 @@ 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 []} +;; ../../../../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 []}) -- 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 + 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 @@ -12840,6 +19399,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 @@ -12914,9 +19506,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $typesd(decl'*{decl' <- `decl'*`}) + 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 @@ -12927,9 +19519,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $importsd(decl'*{decl' <- `decl'*`}) + 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 @@ -12940,9 +19532,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $tagsd(decl'*{decl' <- `decl'*`}) + 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 @@ -12953,9 +19545,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $globalsd(decl'*{decl' <- `decl'*`}) + 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 @@ -12966,9 +19558,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $memsd(decl'*{decl' <- `decl'*`}) + 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 @@ -12979,9 +19571,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $tablesd(decl'*{decl' <- `decl'*`}) + 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 @@ -12992,9 +19584,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $funcsd(decl'*{decl' <- `decl'*`}) + 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 @@ -13005,9 +19597,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $datasd(decl'*{decl' <- `decl'*`}) + 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 @@ -13018,9 +19610,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $elemsd(decl'*{decl' <- `decl'*`}) + 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 @@ -13031,9 +19623,9 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $startsd(decl'*{decl' <- `decl'*`}) + 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 @@ -13044,18 +19636,21 @@ 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'*`}) + 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'*{decl' <- `decl'*`}) = $exportsd(decl'*{decl' <- `decl'*`}) + 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 -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*}: + `%%`(decl#1*{decl#1 <- `decl*`}, true) + -- if ($importsd(decl#2*{decl#2 <- `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*`}) = [])) + rule fun_ordered_case_1{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*`}) = []))) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec relation Context_ok: `|-%:OK`(context) @@ -13064,14 +19659,13 @@ relation Context_ok: `|-%:OK`(context) `|-%:OK`(C) -- 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 (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*`} -- (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*`} ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec @@ -13145,7 +19739,7 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) -- 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*`} -- (Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, deftype))*{deftype <- `deftype*`} @@ -13154,7 +19748,7 @@ relation Moduleinst_ok: `%|-%:%`(store, moduleinst, context) -- 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*`} + -- (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*`|) @@ -13199,11 +19793,11 @@ 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)]))) -- 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)]))) -- Ref_ok: `%|-%:%`(s, ref, rt) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec:18.1-21.68 @@ -13260,7 +19854,7 @@ 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*`}))) -- wf_store: `%`(s) -- wf_context: `%`(C) @@ -13276,8 +19870,9 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- 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*`}))) + -- if (var_0 =/= ?()) + -- 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*`}))) + -- 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}: @@ -13365,10 +19960,10 @@ 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) -- 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 []}) -- Deftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, dt) -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) @@ -13407,7 +20002,7 @@ relation Exninst_ok: `%|-%:OK`(store, exninst) -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) -- if (ta < |s.TAGS_store|) - -- if ((dt : deftype <: typeuse) = s.TAGS_store[ta].TYPE_taginst) + -- 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*`} @@ -13452,7 +20047,7 @@ 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)) + `%>>_%%`(`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) @@ -13460,29 +20055,40 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) ;; ../../../../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 + 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) = 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 $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 _{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) -- wf_fieldval: `%`(fv_1) -- wf_store: `%`(s) -- wf_fieldval: `%`(fv_2) - -- if $NotImmutReachable(fv_1, s, fv_2) + -- if var_0 + -- fun_NotImmutReachable: `%%%%`(fv_1, s, fv_2, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Store_ok: `|-%:OK`(store) @@ -13816,11 +20422,11 @@ 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*, s_2 : store, a : nat, `a'*` : addr*, s_1 : store}(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*, s_2 : store, a : nat, `a'*` : addr*, s_1 : store}(syntax X, syntax Y, s, [X] ++ X'#1*{X'#1 <- `X'*`}, [Y] ++ Y'#1*{Y'#1 <- `Y'*`}) = (s_2, [a] ++ a'*{a' <- `a'*`}) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, a) = $allocX(syntax X, syntax Y, s, X, Y)) - -- if ((s_2, a'*{a' <- `a'*`}) = $allocXs(syntax X, syntax Y, s_1, X'*{X' <- `X'*`}, Y'*{Y' <- `Y'*`})) + -- if ((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.4-notation.binary.spectec @@ -13885,7 +20491,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 @@ -13935,8 +20542,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 @@ -14069,11 +20677,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 @@ -14097,9 +20705,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 @@ -15423,10 +22031,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 @@ -15597,7 +22206,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))] @@ -15610,8 +22220,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 @@ -15775,7 +22386,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 { @@ -15834,10 +22446,12 @@ grammar TfNmag(N : N) : 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)) + prod{var_0 : m} "nan" => NAN_fNmag(var_0) + -- fun_canon_: `%%`(N, var_0) ;; ../../../../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))))) + prod{n : n, var_0 : nat?} {{"nan:0x"} {n:Thexnum}} => NAN_fNmag(n) + -- if ((1 <= n) /\ (n < (2 ^ !(var_0)))) + -- fun_signif: `%%`(N, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar TfN(N : N) : fN @@ -16036,11 +22650,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 @@ -16052,9 +22666,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 @@ -16105,7 +22719,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 @@ -17292,9 +23907,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* @@ -17430,33 +24046,33 @@ 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_1 : bool, 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*`})) @@ -17469,7 +24085,9 @@ grammar Tmodule : module -- 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 var_1 + -- fun_ordered: `%%`(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/11-alias-demut.il b/spectec/test-middlend/specification.exp/11-alias-demut.il new file mode 100644 index 0000000000..f527d52403 --- /dev/null +++ b/spectec/test-middlend/specification.exp/11-alias-demut.il @@ -0,0 +1,24137 @@ + +;; ../../../../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'#1*{n'#1 <- `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'#2*{n'#2 <- `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#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 +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#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) +} + +;; ../../../../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#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** + +;; ../../../../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'#4*{w'#4 <- `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'#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 +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#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'#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 +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'#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 +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#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'#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 +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#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 +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 +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 + 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 +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 + 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 +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 + 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 +relation fun_signif_before_fun_signif_case_2: `%`(N) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_signif_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_signif_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_signif: `%%`(N, nat?) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_signif_case_0: + `%%`(32, ?(23)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_signif_case_1: + `%%`(64, ?(52)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_signif_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_signif_before_fun_signif_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_expon_before_fun_expon_case_2: `%`(N) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_expon: `%%`(N, nat?) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_0: + `%%`(32, ?(8)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_1: + `%%`(64, ?(11)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_expon_before_fun_expon_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_M: `%%`(N, nat) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_M_case_0{N : nat, var_0 : nat?}: + `%%`(N, !(var_0)) + -- if (var_0 =/= ?()) + -- fun_signif: `%%`(N, var_0) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_E: `%%`(N, nat) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_E_case_0{N : nat, var_0 : nat?}: + `%%`(N, !(var_0)) + -- if (var_0 =/= ?()) + -- fun_expon: `%%`(N, var_0) + +;; ../../../../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, var_1 : nat, var_0 : nat}: + `%%`(N, NORM_fNmag(m, exp)) + -- if ((m < (2 ^ var_0)) /\ ((((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= exp) /\ (exp <= (((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) + -- fun_E: `%%`(N, var_1) + -- fun_M: `%%`(N, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fNmag_case_1{N : N, exp : exp, m : m, var_1 : nat, var_0 : nat}: + `%%`(N, SUBNORM_fNmag(m)) + -- if ((m < (2 ^ var_0)) /\ (((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = exp)) + -- fun_E: `%%`(N, var_1) + -- fun_M: `%%`(N, var_0) + + ;; ../../../../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, var_0 : nat}: + `%%`(N, NAN_fNmag(m)) + -- if ((1 <= m) /\ (m < (2 ^ var_0))) + -- fun_M: `%%`(N, var_0) + +;; ../../../../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 +relation fun_fzero: `%%`(N, fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_fzero_case_0{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 fun_fnat: `%%%`(N, nat, fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_fnat_case_0{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 fun_fone: `%%`(N, fN) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_fone_case_0{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 fun_canon_: `%%`(N, nat) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_canon__case_0{N : nat, var_0 : nat?}: + `%%`(N, (2 ^ (((!(var_0) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + -- if (var_0 =/= ?()) + -- fun_signif: `%%`(N, var_0) + +;; ../../../../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 +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 + 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 +relation fun_cont: `%%`(byte, nat) + ;; ../../../../specification/wasm-3.0/5.1-binary.values.spectec + 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*`})) + -- if (|`var_0*`| = |`ch*`|) + -- (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, b : byte}: + `%%`([ch], [b]) + -- wf_byte: `%`(b) + -- wf_byte: `%`(`%`_byte($proj_char_0(ch).0)) + -- if ($proj_char_0(ch).0 < 128) + -- if (`%`_byte($proj_char_0(ch).0) = b) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_2, var_0) + -- wf_byte: `%`(b_1) + -- wf_byte: `%`(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)) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) + -- wf_byte: `%`(b_1) + -- wf_byte: `%`(b_2) + -- wf_byte: `%`(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)) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_4, var_2) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) + -- wf_byte: `%`(b_1) + -- wf_byte: `%`(b_2) + -- wf_byte: `%`(b_3) + -- wf_byte: `%`(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)) +} + +;; ../../../../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*, var_0 : byte*}: + `%`(`%`_name(`char*`)) + -- (wf_char: `%`(char))*{char <- `char*`} + -- if (|var_0| < (2 ^ 32)) + -- fun_utf8: `%%`(char*{char <- `char*`}, var_0) + +;; ../../../../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#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 +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 +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 +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 +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 +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 +relation fun_free_opt: `%%`(free?, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_opt_case_0: + `%%`(?(), {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 + rule fun_free_opt_case_1{free : 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 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 []}) + -- wf_free: `%`({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 +relation fun_free_typeidx: `%%`(typeidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_typeidx_case_0{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 fun_free_funcidx: `%%`(funcidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_funcidx_case_0{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 fun_free_globalidx: `%%`(globalidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_globalidx_case_0{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 fun_free_tableidx: `%%`(tableidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_tableidx_case_0{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 fun_free_memidx: `%%`(memidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_memidx_case_0{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 fun_free_elemidx: `%%`(elemidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_elemidx_case_0{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 fun_free_dataidx: `%%`(dataidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_dataidx_case_0{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 fun_free_localidx: `%%`(localidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_localidx_case_0{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 fun_free_labelidx: `%%`(labelidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_labelidx_case_0{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 fun_free_tagidx: `%%`(tagidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_tagidx_case_0{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 fun_free_externidx: `%%`(externidx, free) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_externidx_case_0{funcidx : uN, var_0 : free}: + `%%`(FUNC_externidx(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_externidx_case_1{globalidx : uN, var_0 : free}: + `%%`(GLOBAL_externidx(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_externidx_case_2{tableidx : uN, var_0 : free}: + `%%`(TABLE_externidx(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_externidx_case_3{memidx : uN, var_0 : free}: + `%%`(MEM_externidx(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_free_externidx_case_4{tagidx : uN, var_0 : free}: + `%%`(TAG_externidx(tagidx), var_0) + -- fun_free_tagidx: `%%`(tagidx, var_0) + +;; ../../../../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 + +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 + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +syntax consttype = + | I32 + | I64 + | F32 + | 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 + | 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: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 : list(syntax valtype), resulttype : list(syntax valtype)) + +;; ../../../../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 +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 { + +;; ../../../../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) + +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 + 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) + +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 + 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 + +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 + +;; ../../../../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 +relation fun_ANYREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_ANYREF_case_0: + `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), ANY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_EQREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_EQREF_case_0: + `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), EQ_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_I31REF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_I31REF_case_0: + `%`(REF_reftype(?(NULL_null), I31_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), I31_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_STRUCTREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_STRUCTREF_case_0: + `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), STRUCT_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_ARRAYREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_ARRAYREF_case_0: + `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), ARRAY_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_FUNCREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FUNCREF_case_0: + `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), FUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_EXNREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_EXNREF_case_0: + `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_EXTERNREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_EXTERNREF_case_0: + `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), EXTERN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_NULLREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_NULLREF_case_0: + `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), NONE_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_NULLFUNCREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_NULLFUNCREF_case_0: + `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOFUNC_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_NULLEXNREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_NULLEXNREF_case_0: + `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXN_heaptype)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_NULLEXTERNREF: `%`(reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_NULLEXTERNREF_case_0: + `%`(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 + +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 + | I64 + | F32 + | F64 + | 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 + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +syntax Jnn = + | I32 + | I64 + | 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 + +;; ../../../../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) + +;; ../../../../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 +relation fun_IN_before_fun_IN_case_2: `%`(N) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_IN_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_IN_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_IN: `%%`(N, Inn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_IN_case_0: + `%%`(32, ?(I32_Inn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_IN_case_1: + `%%`(64, ?(I64_Inn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_IN_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_IN_before_fun_IN_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_FN_before_fun_FN_case_2: `%`(N) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_FN: `%%`(N, Fnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_0: + `%%`(32, ?(F32_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_1: + `%%`(64, ?(F64_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_FN_before_fun_FN_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_JN_before_fun_JN_case_4: `%`(N) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_3: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_2: + `%`(32) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_1: + `%`(16) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_0: + `%`(8) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_JN: `%%`(N, Jnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_0: + `%%`(8, ?(I8_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_1: + `%%`(16, ?(I16_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_2: + `%%`(32, ?(I32_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_3: + `%%`(64, ?(I64_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_4{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_JN_before_fun_JN_case_4: `%`(x0) + +;; ../../../../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(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(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 +relation fun_zsize_before_fun_zsize_case_7: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_6: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_5: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_4: + `%`(V128_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_zsize: `%%`(storagetype, nat?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_0: + `%%`(I32_storagetype, ?($size(I32_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_1: + `%%`(I64_storagetype, ?($size(I64_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_2: + `%%`(F32_storagetype, ?($size(F32_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_3: + `%%`(F64_storagetype, ?($size(F64_numtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_4: + `%%`(V128_storagetype, ?($vsize(V128_vectype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_5: + `%%`(I8_storagetype, ?($psize(I8_packtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_6: + `%%`(I16_storagetype, ?($psize(I16_packtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_7{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_zsize_before_fun_zsize_case_7: `%`(x0) + +;; ../../../../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($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($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($numtype_Fnn(Fnn)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_isize_before_fun_inv_isize_case_2: `%`(nat) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_isize_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_isize_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_isize: `%%`(nat, Inn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_isize_case_0: + `%%`(32, ?(I32_Inn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_isize_case_1: + `%%`(64, ?(I64_Inn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_isize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_inv_isize_before_fun_inv_isize_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_jsize: `%%`(nat, Jnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_jsize_case_0: + `%%`(8, ?(I8_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_jsize_case_1: + `%%`(16, ?(I16_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_jsize_case_2{n : nat, var_0 : Inn?}: + `%%`(n, $Jnn_addrtype(iter_val#1)?{iter_val#1 <- var_0}) + -- fun_inv_isize: `%%`(n, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(nat) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_fsize: `%%`(nat, Fnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_0: + `%%`(32, ?(F32_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_1: + `%%`(64, ?(F64_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(x0) + +;; ../../../../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($lanetype_Jnn(Jnn)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_jsizenn: `%%`(nat, Jnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_jsizenn_case_0{n : nat, var_0 : Jnn?}: + `%%`(n, var_0) + -- fun_inv_jsize: `%%`(n, var_0) + +;; ../../../../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(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(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 +relation fun_unpack: `%%`(storagetype, valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_0: + `%%`(BOT_storagetype, BOT_valtype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_1{`null?` : null?, heaptype : heaptype}: + `%%`(REF_storagetype(`null?`, heaptype), REF_valtype(`null?`, heaptype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_2: + `%%`(V128_storagetype, V128_valtype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_3: + `%%`(F64_storagetype, F64_valtype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_4: + `%%`(F32_storagetype, F32_valtype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_5: + `%%`(I64_storagetype, I64_valtype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_6: + `%%`(I32_storagetype, I32_valtype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_7: + `%%`(I8_storagetype, I32_valtype) + -- wf_valtype: `%`(I32_valtype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_unpack_case_8: + `%%`(I16_storagetype, I32_valtype) + -- wf_valtype: `%`(I32_valtype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_nunpack_before_fun_nunpack_case_6: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_5: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_4: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_nunpack: `%%`(storagetype, numtype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_0: + `%%`(I32_storagetype, ?(I32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_1: + `%%`(I64_storagetype, ?(I64_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_2: + `%%`(F32_storagetype, ?(F32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_3: + `%%`(F64_storagetype, ?(F64_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_4: + `%%`(I8_storagetype, ?(I32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_5: + `%%`(I16_storagetype, ?(I32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_6{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_nunpack_before_fun_nunpack_case_6: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_vunpack_before_fun_vunpack_case_1: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_vunpack_case_0: + `%`(V128_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_vunpack: `%%`(storagetype, vectype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_vunpack_case_0: + `%%`(V128_storagetype, ?(V128_vectype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_vunpack_case_1{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_vunpack_before_fun_vunpack_case_1: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_cunpack_before_fun_cunpack_case_13: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_12: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_11: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_10: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_9: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_8: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_7: + `%`(I32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_6: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_5: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_4: + `%`(V128_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_cunpack: `%%`(storagetype, consttype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_0: + `%%`(I32_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_1: + `%%`(I64_storagetype, ?(I64_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_2: + `%%`(F32_storagetype, ?(F32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_3: + `%%`(F64_storagetype, ?(F64_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_4: + `%%`(V128_storagetype, ?(V128_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_5: + `%%`(I8_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_6: + `%%`(I16_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_7: + `%%`(I32_storagetype, ?($consttype_numtype($lunpack(I32_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_8: + `%%`(I64_storagetype, ?($consttype_numtype($lunpack(I64_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_9: + `%%`(F32_storagetype, ?($consttype_numtype($lunpack(F32_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_10: + `%%`(F64_storagetype, ?($consttype_numtype($lunpack(F64_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_11: + `%%`(I8_storagetype, ?($consttype_numtype($lunpack(I8_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_12: + `%%`(I16_storagetype, ?($consttype_numtype($lunpack(I16_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_13{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_cunpack_before_fun_cunpack_case_13: `%`(x0) + +;; ../../../../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($numtype_addrtype(at_1)) <= $size($numtype_addrtype(at_2))) then at_1 else at_2) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_diffrt: `%%%`(reftype, reftype, reftype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_diffrt_case_0{`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 + rule fun_diffrt_case_1{`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 fun_as_deftype_before_fun_as_deftype_case_1: `%`(typeuse) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_0{rectype : rectype, n : n}: + `%`(_DEF_typeuse(rectype, n)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_as_deftype: `%%`(typeuse, deftype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_0{rectype : rectype, n : n}: + `%%`(_DEF_typeuse(rectype, n), ?(_DEF_deftype(rectype, n))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_1{x0 : typeuse}: + `%%`(x0, ?()) + -- ~ fun_as_deftype_before_fun_as_deftype_case_1: `%`(x0) + +;; ../../../../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 +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 +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 +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 +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 +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:401.6-401.17 +relation fun_minus_recs_before_fun_minus_recs_case_3: `%%`(typevar*, typeuse*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%`([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) + -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} + -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} + -- wf_typevar: `%`(_IDX_typevar(x)) + -- if (var_0 =/= ?()) + -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_0: + `%%`([], []) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_0: + `%%%`([], [], ?(([], []))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}, var_0) + -- fun_minus_recs: `%%%`(tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, 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'*`}))) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) + -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} + -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} + -- wf_typevar: `%`(_IDX_typevar(x)) + -- if (var_0 =/= ?()) + -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_3{x0 : typevar*, x1 : typeuse*}: + `%%%`(x0, x1, ?()) + -- ~ fun_minus_recs_before_fun_minus_recs_case_3: `%%`(x0, x1) +} + +;; ../../../../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#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#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#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.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)) + -- if (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)) + -- if (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))) + -- if (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))) + -- if (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_1 : heaptype, 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#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, var_1) + -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) + +;; ../../../../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#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:345.6-345.20 + rule fun_subst_valtype_case_1{`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:345.6-345.20 + rule fun_subst_valtype_case_2{`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:345.6-345.20 + rule fun_subst_valtype_case_3{`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:345.6-345.20 + rule fun_subst_valtype_case_4{`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: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#32*{tv#32 <- `tv*`}, tu#32*{tu#32 <- `tu*`}, $valtype_reftype(var_0)) + -- fun_subst_reftype: `%%%%`(REF_reftype(`null?`, heaptype), tv#33*{tv#33 <- `tv*`}, tu#33*{tu#33 <- `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#34*{tv#34 <- `tv*`}, tu#34*{tu#34 <- `tu*`}, BOT_valtype) + -- wf_valtype: `%`(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#35*{tv#35 <- `tv*`}, tu#35*{tu#35 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(BOT_valtype, tv#36*{tv#36 <- `tv*`}, tu#36*{tu#36 <- `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#37*{tv#37 <- `tv*`}, tu#37*{tu#37 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(REF_valtype(`null?`, heaptype), tv#38*{tv#38 <- `tv*`}, tu#38*{tu#38 <- `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#39*{tv#39 <- `tv*`}, tu#39*{tu#39 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(V128_valtype, tv#40*{tv#40 <- `tv*`}, tu#40*{tu#40 <- `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#41*{tv#41 <- `tv*`}, tu#41*{tu#41 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F64_valtype, tv#42*{tv#42 <- `tv*`}, tu#42*{tu#42 <- `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#43*{tv#43 <- `tv*`}, tu#43*{tu#43 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(F32_valtype, tv#44*{tv#44 <- `tv*`}, tu#44*{tu#44 <- `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#45*{tv#45 <- `tv*`}, tu#45*{tu#45 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I64_valtype, tv#46*{tv#46 <- `tv*`}, tu#46*{tu#46 <- `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#47*{tv#47 <- `tv*`}, tu#47*{tu#47 <- `tu*`}, $storagetype_valtype(var_0)) + -- fun_subst_valtype: `%%%%`(I32_valtype, tv#48*{tv#48 <- `tv*`}, tu#48*{tu#48 <- `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#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:348.6-348.24 + rule fun_subst_storagetype_case_8{`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.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_1 : storagetype, var_0 : storagetype}: + `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_storagetype: `%%%%`(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, var_1) + -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) + +;; ../../../../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_1*` : fieldtype*, `var_0*` : fieldtype*}: + `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- if (|`var_1*`| = |`ft*`|) + -- (fun_subst_fieldtype: `%%%%`(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, var_1))*{var_1 <- `var_1*`, ft#2 <- `ft*`} + -- if (|`var_0*`| = |`ft*`|) + -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) + + ;; ../../../../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_1 : fieldtype, var_0 : fieldtype}: + `%%%%`(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, ARRAY_comptype(var_0)) + -- fun_subst_fieldtype: `%%%%`(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}, var_1) + -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_comptype: `%`(ARRAY_comptype(var_1)) + + ;; ../../../../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_3*` : valtype*, `var_2*` : valtype*, `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#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- if (|`var_3*`| = |`t_2*`|) + -- (fun_subst_valtype: `%%%%`(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_3))*{var_3 <- `var_3*`, t_2#2 <- `t_2*`} + -- if (|`var_2*`| = |`t_1*`|) + -- (fun_subst_valtype: `%%%%`(t_1#2, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}, var_2))*{var_2 <- `var_2*`, t_1#2 <- `t_1*`} + -- if (|`var_1*`| = |`t_2*`|) + -- (fun_subst_valtype: `%%%%`(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, t_2 <- `t_2*`} + -- if (|`var_0*`| = |`t_1*`|) + -- (fun_subst_valtype: `%%%%`(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, t_1 <- `t_1*`} + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) + +;; ../../../../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_3 : comptype, `var_2*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: + `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#4*{tu'#4 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- fun_subst_comptype: `%%%%`(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, var_3) + -- if (|`var_2*`| = |`tu'*`|) + -- (fun_subst_typeuse: `%%%%`(tu'#5, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}, var_2))*{var_2 <- `var_2*`, tu'#5 <- `tu'*`} + -- fun_subst_comptype: `%%%%`(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1) + -- if (|`var_0*`| = |`tu'*`|) + -- (fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, tu' <- `tu'*`} + -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) + +;; ../../../../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*, `tv'*` : typevar*, `tu'*` : typeuse*, var_1 : (typevar*, typeuse*)?, `var_0*` : subtype*}: + `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) + -- if (|`var_0*`| = |`st*`|) + -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} + -- (wf_typevar: `%`(tv'#4))*{tv'#4 <- `tv'*`} + -- (wf_typeuse: `%`(tu'#6))*{tu'#6 <- `tu'*`} + -- if (var_1 =/= ?()) + -- if ((tv'#5*{tv'#5 <- `tv'*`}, tu'#7*{tu'#7 <- `tu'*`}) = !(var_1)) + +;; ../../../../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#67*{tv#67 <- `tv*`}, tu#67*{tu#67 <- `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 +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 + +;; ../../../../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#69*{tv#69 <- `tv*`}, tu#69*{tu#69 <- `tu*`}, var_0) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, 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 + rule fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : valtype, var_0 : valtype}: + `%%%%`(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- fun_subst_valtype: `%%%%`(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}, var_1) + -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_subst_memtype: `%%%%`(memtype, typevar*, typeuse*, memtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_memtype_case_0{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)) + +;; ../../../../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_1 : reftype, var_0 : reftype}: + `%%%%`(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- fun_subst_reftype: `%%%%`(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}, var_1) + -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) + +;; ../../../../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_1 : tagtype, var_0 : tagtype}: + `%%%%`(TAG_externtype(jt), tv#75*{tv#75 <- `tv*`}, tu#75*{tu#75 <- `tu*`}, TAG_externtype(var_0)) + -- fun_subst_tagtype: `%%%%`(jt, tv#76*{tv#76 <- `tv*`}, tu#76*{tu#76 <- `tu*`}, var_1) + -- fun_subst_tagtype: `%%%%`(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(TAG_externtype(var_1)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_1{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : globaltype, var_0 : globaltype}: + `%%%%`(GLOBAL_externtype(gt), tv#77*{tv#77 <- `tv*`}, tu#77*{tu#77 <- `tu*`}, GLOBAL_externtype(var_0)) + -- fun_subst_globaltype: `%%%%`(gt, tv#78*{tv#78 <- `tv*`}, tu#78*{tu#78 <- `tu*`}, var_1) + -- fun_subst_globaltype: `%%%%`(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(GLOBAL_externtype(var_1)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_2{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : tabletype, var_0 : tabletype}: + `%%%%`(TABLE_externtype(tt), tv#79*{tv#79 <- `tv*`}, tu#79*{tu#79 <- `tu*`}, TABLE_externtype(var_0)) + -- fun_subst_tabletype: `%%%%`(tt, tv#80*{tv#80 <- `tv*`}, tu#80*{tu#80 <- `tu*`}, var_1) + -- fun_subst_tabletype: `%%%%`(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(TABLE_externtype(var_1)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_3{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : memtype, var_0 : memtype}: + `%%%%`(MEM_externtype(mt), tv#81*{tv#81 <- `tv*`}, tu#81*{tu#81 <- `tu*`}, MEM_externtype(var_0)) + -- fun_subst_memtype: `%%%%`(mt, tv#82*{tv#82 <- `tv*`}, tu#82*{tu#82 <- `tu*`}, var_1) + -- fun_subst_memtype: `%%%%`(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(MEM_externtype(var_1)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_subst_externtype_case_4{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_1 : typeuse, var_0 : typeuse}: + `%%%%`(FUNC_externtype(tu'), tv#83*{tv#83 <- `tv*`}, tu#83*{tu#83 <- `tu*`}, FUNC_externtype(var_0)) + -- fun_subst_typeuse: `%%%%`(tu', tv#84*{tv#84 <- `tv*`}, tu#84*{tu#84 <- `tu*`}, var_1) + -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) + -- wf_externtype: `%`(FUNC_externtype(var_1)) + +;; ../../../../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_3*` : externtype*, `var_2*` : externtype*, `var_1*` : externtype*, `var_0*` : externtype*}: + `%%%%`(`%->%`_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(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- if (|`var_3*`| = |`xt_2*`|) + -- (fun_subst_externtype: `%%%%`(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`}, var_3))*{var_3 <- `var_3*`, xt_2#2 <- `xt_2*`} + -- if (|`var_2*`| = |`xt_1*`|) + -- (fun_subst_externtype: `%%%%`(xt_1#2, tv#86*{tv#86 <- `tv*`}, tu#86*{tu#86 <- `tu*`}, var_2))*{var_2 <- `var_2*`, xt_1#2 <- `xt_1*`} + -- if (|`var_1*`| = |`xt_2*`|) + -- (fun_subst_externtype: `%%%%`(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, xt_2 <- `xt_2*`} + -- if (|`var_0*`| = |`xt_1*`|) + -- (fun_subst_externtype: `%%%%`(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, xt_1 <- `xt_1*`} + -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) + +;; ../../../../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#88^n{tu#88 <- `tu*`}, var_0) + -- 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#3?{final#3 <- `final?`}, typeuse#1*{typeuse#1 <- `typeuse*`}, comptype), var_0 +++ var_2) + -- fun_free_comptype: `%%`(comptype, var_2) + -- if (|`var_1*`| = |`typeuse*`|) + -- (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#9*{subtype#9 <- `subtype*`})), var_0) + -- if (|`var_1*`| = |`subtype*`|) + -- (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 +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 fun_free_globaltype: `%%`(globaltype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_globaltype_case_0{`mut?` : mut?, valtype : valtype, var_0 : free}: + `%%`(`%%`_globaltype(mut#6?{mut#6 <- `mut?`}, valtype), var_0) + -- fun_free_valtype: `%%`(valtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_memtype: `%%`(memtype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_memtype_case_0{addrtype : addrtype, limits : limits, var_0 : free}: + `%%`(`%%PAGE`_memtype(addrtype, limits), var_0) + -- fun_free_addrtype: `%%`(addrtype, var_0) + +;; ../../../../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_1 : free, var_0 : free}: + `%%`(`%%%`_tabletype(addrtype, limits, reftype), var_0 +++ var_1) + -- fun_free_reftype: `%%`(reftype, var_1) + -- fun_free_addrtype: `%%`(addrtype, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_free_datatype: `%%`(datatype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_free_datatype_case_0: + `%%`(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 +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 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 + rule fun_free_externtype_case_2{memtype : memtype, var_0 : free}: + `%%`(MEM_externtype(memtype), var_0) + -- fun_free_memtype: `%%`(memtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + 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 + 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 fun_free_moduletype: `%%`(moduletype, free) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + 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) + -- if (|`var_3*`| = |`externtype_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) + -- if (|`var_1*`| = |`externtype_1*`|) + -- (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.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($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($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? + ;; ../../../../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 = $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 = $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($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_? + ;; ../../../../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 = $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 = $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 = $storagetype_packtype(packtype)) + +;; ../../../../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 +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 + 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 ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) + +;; ../../../../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 = $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 = $numtype_Fnn(Fnn)) + +;; ../../../../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 = $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 = $numtype_Fnn(Fnn)) + +;; ../../../../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 = $numtype_addrtype(Inn)) + +;; ../../../../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 = $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 = $numtype_Fnn(Fnn)) + +;; ../../../../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($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($numtype_addrtype(Inn_1)) > $sizenn2($numtype_addrtype(Inn_2))) + +;; ../../../../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($numtype_addrtype(Inn_1)) = $sizenn2($numtype_Fnn(Fnn_2))) + +;; ../../../../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($numtype_Fnn(Fnn_1)) = $sizenn2($numtype_addrtype(Inn_2))) + +;; ../../../../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($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($numtype_Fnn(Fnn_1)) > $sizenn2($numtype_Fnn(Fnn_2))) + +;; ../../../../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 = $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 = $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 = $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 = $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? + ;; ../../../../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 +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 + 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) * $proj_dim_0(dim).0) = 128) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation fun_dim: `%%`(shape, dim) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_dim_case_0{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 +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) = $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 + 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($lanetype_Jnn(Jnn)) = 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($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($lanetype_Fnn(Fnn), `%`_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($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($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($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($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($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($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($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($lanetype_Jnn(Jnn)) <= 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($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($lanetype_Fnn(Fnn), `%`_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($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($lanetype_Fnn(Fnn), `%`_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($lanetype_Jnn(Jnn), `%`_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($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($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($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($lanetype_Jnn(Jnn)) =/= 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($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($lanetype_Fnn(Fnn), `%`_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($lanetype_Jnn(Jnn), `%`_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($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__ = + | 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($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 + ;; ../../../../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($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($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($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__ = + | 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($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 + ;; ../../../../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($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__ = + | 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($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 + ;; ../../../../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($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 = + | 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($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 = + | 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($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($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 = + | 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($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($numtype_Fnn(Fnn_1))) = $sizenn2($numtype_Fnn(Fnn_2))) + +;; ../../../../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($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($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($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($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? + ;; ../../../../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 ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) + +;; ../../../../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 = $numtype_addrtype(Inn)) + +;; ../../../../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 ($proj_sz_0(sz).0 < $sizenn($numtype_addrtype(Inn))) + +;; ../../../../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 = $numtype_addrtype(Inn)) + +;; ../../../../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 ((($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}: + `%%`(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 ($proj_sz_0(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) + +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 + 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 +} + +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 { + +;; ../../../../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*, var_0 : dim}: + `%`(VSHUFFLE_instr(bshape, `laneidx*`)) + -- wf_bshape: `%`(bshape) + -- (wf_uN: `%%`(8, laneidx))*{laneidx <- `laneidx*`} + -- if (`%`_dim(|laneidx*{laneidx <- `laneidx*`}|) = var_0) + -- fun_dim: `%%`($proj_bshape_0(bshape).0, var_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($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__}: + `%`(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 (|[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 + 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 +relation fun_memarg0: `%`(memarg) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_memarg0_case_0: + `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + -- wf_memarg: `%`({ALIGN `%`_u32(0), OFFSET `%`_u64(0)}) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation fun_const: `%%%`(consttype, lit_, instr) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_const_case_0{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 + rule fun_const_case_1{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 + rule fun_const_case_2{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 + rule fun_const_case_3{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 + rule fun_const_case_4{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 fun_free_shape: `%%`(shape, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_shape_case_0{lanetype : lanetype, dim : dim, var_0 : free}: + `%%`(`%X%`_shape(lanetype, dim), var_0) + -- fun_free_lanetype: `%%`(lanetype, var_0) + +;; ../../../../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_1?` : free?, var_0 : free}: + `%%`(_RESULT_blocktype(valtype#505?{valtype#505 <- `valtype?`}), var_0) + -- if ((`var_1?` = ?()) <=> (`valtype?` = ?())) + -- (fun_free_valtype: `%%`(valtype, var_1))?{var_1 <- `var_1?`, valtype <- `valtype?`} + -- fun_free_opt: `%%`(var_1?{var_1 <- `var_1?`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_blocktype_case_1{typeidx : uN, var_0 : free}: + `%%`(_IDX_blocktype(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +relation fun_free_catch: `%%`(catch, free) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_catch_case_0{tagidx : uN, labelidx : uN, var_1 : free, var_0 : free}: + `%%`(CATCH_catch(tagidx, labelidx), var_0 +++ var_1) + -- fun_free_labelidx: `%%`(labelidx, var_1) + -- fun_free_tagidx: `%%`(tagidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_catch_case_1{tagidx : uN, labelidx : uN, var_1 : free, var_0 : free}: + `%%`(CATCH_REF_catch(tagidx, labelidx), var_0 +++ var_1) + -- fun_free_labelidx: `%%`(labelidx, var_1) + -- fun_free_tagidx: `%%`(tagidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_catch_case_2{labelidx : uN, var_0 : free}: + `%%`(CATCH_ALL_catch(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec + rule fun_free_catch_case_3{labelidx : uN, var_0 : free}: + `%%`(CATCH_ALL_REF_catch(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + +;; ../../../../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) + -- 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 +rec { + +;; ../../../../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 []}) + -- wf_free: `%`({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 []}) + -- wf_free: `%`({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 []}) + -- wf_free: `%`({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_2*?` : free*?, `var_1?` : free?, var_0 : free}: + `%%`(SELECT_instr(valtype#506*{valtype#506 <- `valtype*#1`}?{`valtype*#1` <- `valtype*?`}), var_0) + -- if ((`var_2*?` = ?()) <=> (`valtype*?` = ?())) + -- (if (|`var_2*`| = |`valtype*`|))?{`var_2*` <- `var_2*?`, `valtype*` <- `valtype*?`} + -- (fun_free_valtype: `%%`(valtype, var_2))*{var_2 <- `var_2*`, valtype <- `valtype*`}?{`var_2*` <- `var_2*?`, `valtype*` <- `valtype*?`} + -- if ((`var_2*?` = ?()) <=> (`var_1?` = ?())) + -- (fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1))?{`var_2*` <- `var_2*?`, var_1 <- `var_1?`} + -- fun_free_opt: `%%`(var_1?{var_1 <- `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, var_0 : free}: + `%%`(BR_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_8{labelidx : uN, var_0 : free}: + `%%`(BR_IF_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_9{`labelidx*` : labelidx*, labelidx' : uN, var_2 : free, `var_1*` : free*, var_0 : free}: + `%%`(BR_TABLE_instr(labelidx#1*{labelidx#1 <- `labelidx*`}, labelidx'), var_0 +++ var_2) + -- fun_free_labelidx: `%%`(labelidx', var_2) + -- if (|`var_1*`| = |`labelidx*`|) + -- (fun_free_labelidx: `%%`(labelidx, var_1))*{var_1 <- `var_1*`, labelidx <- `labelidx*`} + -- fun_free_list: `%%`(var_1*{var_1 <- `var_1*`}, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_10{labelidx : uN, var_0 : free}: + `%%`(BR_ON_NULL_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_11{labelidx : uN, var_0 : free}: + `%%`(BR_ON_NON_NULL_instr(labelidx), var_0) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../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_2 : free, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_instr(labelidx, reftype_1, reftype_2), var_0 +++ var_1 +++ var_2) + -- fun_free_reftype: `%%`(reftype_2, var_2) + -- fun_free_reftype: `%%`(reftype_1, var_1) + -- fun_free_labelidx: `%%`(labelidx, 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_2 : free, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_FAIL_instr(labelidx, reftype_1, reftype_2), var_0 +++ var_1 +++ var_2) + -- fun_free_reftype: `%%`(reftype_2, var_2) + -- fun_free_reftype: `%%`(reftype_1, var_1) + -- fun_free_labelidx: `%%`(labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_14{funcidx : uN, var_0 : free}: + `%%`(CALL_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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_1 : free, var_0 : free}: + `%%`(CALL_INDIRECT_instr(tableidx, typeuse), var_0 +++ var_1) + -- fun_free_typeuse: `%%`(typeuse, var_1) + -- fun_free_tableidx: `%%`(tableidx, 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 []}) + -- wf_free: `%`({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, var_0 : free}: + `%%`(RETURN_CALL_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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_1 : free, var_0 : free}: + `%%`(RETURN_CALL_INDIRECT_instr(tableidx, typeuse), var_0 +++ var_1) + -- fun_free_typeuse: `%%`(typeuse, var_1) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_21{tagidx : uN, var_0 : free}: + `%%`(THROW_instr(tagidx), var_0) + -- fun_free_tagidx: `%%`(tagidx, var_0) + + ;; ../../../../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 []}) + -- wf_free: `%`({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_4*` : free*, 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_3) + -- if (|`var_4*`| = |`instr*`|) + -- (fun_free_instr: `%%`(instr, var_4))*{var_4 <- `var_4*`, instr <- `instr*`} + -- fun_free_list: `%%`(var_4*{var_4 <- `var_4*`}, var_3) + -- if (|`var_2*`| = |`catch*`|) + -- (fun_free_catch: `%%`(catch, var_2))*{var_2 <- `var_2*`, catch <- `catch*`} + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, 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_, var_0 : free}: + `%%`(CONST_instr(numtype, numlit), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_25{numtype : numtype, unop : unop_, var_0 : free}: + `%%`(UNOP_instr(numtype, unop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_26{numtype : numtype, binop : binop_, var_0 : free}: + `%%`(BINOP_instr(numtype, binop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_27{numtype : numtype, testop : testop_, var_0 : free}: + `%%`(TESTOP_instr(numtype, testop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_28{numtype : numtype, relop : relop_, var_0 : free}: + `%%`(RELOP_instr(numtype, relop), var_0) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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__, var_1 : free, var_0 : free}: + `%%`(CVTOP_instr(numtype_1, numtype_2, cvtop), var_0 +++ var_1) + -- fun_free_numtype: `%%`(numtype_2, var_1) + -- fun_free_numtype: `%%`(numtype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_30{vectype : vectype, veclit : uN, var_0 : free}: + `%%`(VCONST_instr(vectype, veclit), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_31{vectype : vectype, vvunop : vvunop, var_0 : free}: + `%%`(VVUNOP_instr(vectype, vvunop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_32{vectype : vectype, vvbinop : vvbinop, var_0 : free}: + `%%`(VVBINOP_instr(vectype, vvbinop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_33{vectype : vectype, vvternop : vvternop, var_0 : free}: + `%%`(VVTERNOP_instr(vectype, vvternop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_34{vectype : vectype, vvtestop : vvtestop, var_0 : free}: + `%%`(VVTESTOP_instr(vectype, vvtestop), var_0) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_35{shape : shape, vunop : vunop_, var_0 : free}: + `%%`(VUNOP_instr(shape, vunop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_36{shape : shape, vbinop : vbinop_, var_0 : free}: + `%%`(VBINOP_instr(shape, vbinop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_37{shape : shape, vternop : vternop_, var_0 : free}: + `%%`(VTERNOP_instr(shape, vternop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_38{shape : shape, vtestop : vtestop_, var_0 : free}: + `%%`(VTESTOP_instr(shape, vtestop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_39{shape : shape, vrelop : vrelop_, var_0 : free}: + `%%`(VRELOP_instr(shape, vrelop), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_40{ishape : ishape, vshiftop : vshiftop_, var_0 : free}: + `%%`(VSHIFTOP_instr(ishape, vshiftop), var_0) + -- fun_free_shape: `%%`($proj_ishape_0(ishape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_41{ishape : ishape, var_0 : free}: + `%%`(VBITMASK_instr(ishape), var_0) + -- fun_free_shape: `%%`($proj_ishape_0(ishape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_42{bshape : bshape, vswizzlop : vswizzlop_, var_0 : free}: + `%%`(VSWIZZLOP_instr(bshape, vswizzlop), var_0) + -- fun_free_shape: `%%`($proj_bshape_0(bshape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_43{bshape : bshape, `laneidx*` : laneidx*, var_0 : free}: + `%%`(VSHUFFLE_instr(bshape, laneidx#1*{laneidx#1 <- `laneidx*`}), var_0) + -- fun_free_shape: `%%`($proj_bshape_0(bshape).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTUNOP_instr(ishape_1, ishape_2, vextunop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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, var_1 : free, var_0 : free}: + `%%`(VNARROW_instr(ishape_1, ishape_2, sx), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VCVTOP_instr(shape_1, shape_2, vcvtop), var_0 +++ var_1) + -- fun_free_shape: `%%`(shape_2, var_1) + -- fun_free_shape: `%%`(shape_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_49{shape : shape, var_0 : free}: + `%%`(VSPLAT_instr(shape), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VEXTRACT_LANE_instr(shape, sx#43187?{sx#43187 <- `sx?`}, laneidx), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_51{shape : shape, laneidx : uN, var_0 : free}: + `%%`(VREPLACE_LANE_instr(shape, laneidx), var_0) + -- fun_free_shape: `%%`(shape, var_0) + + ;; ../../../../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 []}) + -- wf_free: `%`({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 []}) + -- wf_free: `%`({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 []}) + -- wf_free: `%`({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, var_0 : free}: + `%%`(`REF.FUNC`_instr(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + + ;; ../../../../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 []}) + -- wf_free: `%`({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 []}) + -- wf_free: `%`({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, var_0 : free}: + `%%`(`STRUCT.NEW`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_62{typeidx : uN, var_0 : free}: + `%%`(`STRUCT.NEW_DEFAULT`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(`STRUCT.GET`_instr(sx#43188?{sx#43188 <- `sx?`}, typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_64{typeidx : uN, u32 : uN, var_0 : free}: + `%%`(`STRUCT.SET`_instr(typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_65{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.NEW`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_66{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.NEW_DEFAULT`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_67{typeidx : uN, u32 : uN, var_0 : free}: + `%%`(`ARRAY.NEW_FIXED`_instr(typeidx, u32), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_68{typeidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.NEW_DATA`_instr(typeidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_69{typeidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.NEW_ELEM`_instr(typeidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_70{`sx?` : sx?, typeidx : uN, var_0 : free}: + `%%`(`ARRAY.GET`_instr(sx#43189?{sx#43189 <- `sx?`}, typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_71{typeidx : uN, var_0 : free}: + `%%`(`ARRAY.SET`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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 []}) + -- wf_free: `%`({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, var_0 : free}: + `%%`(`ARRAY.FILL`_instr(typeidx), var_0) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`ARRAY.COPY`_instr(typeidx_1, typeidx_2), var_0 +++ var_1) + -- fun_free_typeidx: `%%`(typeidx_2, var_1) + -- fun_free_typeidx: `%%`(typeidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_75{typeidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.INIT_DATA`_instr(typeidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_76{typeidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`ARRAY.INIT_ELEM`_instr(typeidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_typeidx: `%%`(typeidx, var_0) + + ;; ../../../../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 []}) + -- wf_free: `%`({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 []}) + -- wf_free: `%`({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, var_0 : free}: + `%%`(`LOCAL.GET`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_80{localidx : uN, var_0 : free}: + `%%`(`LOCAL.SET`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_81{localidx : uN, var_0 : free}: + `%%`(`LOCAL.TEE`_instr(localidx), var_0) + -- fun_free_localidx: `%%`(localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_82{globalidx : uN, var_0 : free}: + `%%`(`GLOBAL.GET`_instr(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_83{globalidx : uN, var_0 : free}: + `%%`(`GLOBAL.SET`_instr(globalidx), var_0) + -- fun_free_globalidx: `%%`(globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_84{tableidx : uN, var_0 : free}: + `%%`(`TABLE.GET`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_85{tableidx : uN, var_0 : free}: + `%%`(`TABLE.SET`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_86{tableidx : uN, var_0 : free}: + `%%`(`TABLE.SIZE`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_87{tableidx : uN, var_0 : free}: + `%%`(`TABLE.GROW`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_88{tableidx : uN, var_0 : free}: + `%%`(`TABLE.FILL`_instr(tableidx), var_0) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`TABLE.COPY`_instr(tableidx_1, tableidx_2), var_0 +++ var_1) + -- fun_free_tableidx: `%%`(tableidx_2, var_1) + -- fun_free_tableidx: `%%`(tableidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_90{tableidx : uN, elemidx : uN, var_1 : free, var_0 : free}: + `%%`(`TABLE.INIT`_instr(tableidx, elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(elemidx, var_1) + -- fun_free_tableidx: `%%`(tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_91{elemidx : uN, var_0 : free}: + `%%`(`ELEM.DROP`_instr(elemidx), var_0) + -- fun_free_elemidx: `%%`(elemidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(LOAD_instr(numtype, loadop#1?{loadop#1 <- `loadop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(STORE_instr(numtype, storeop#1?{storeop#1 <- `storeop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_numtype: `%%`(numtype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VLOAD_instr(vectype, vloadop#1?{vloadop#1 <- `vloadop?`}, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VLOAD_LANE_instr(vectype, sz, memidx, memarg, laneidx), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VSTORE_instr(vectype, memidx, memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VSTORE_LANE_instr(vectype, sz, memidx, memarg, laneidx), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx, var_1) + -- fun_free_vectype: `%%`(vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_98{memidx : uN, var_0 : free}: + `%%`(`MEMORY.SIZE`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_99{memidx : uN, var_0 : free}: + `%%`(`MEMORY.GROW`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_100{memidx : uN, var_0 : free}: + `%%`(`MEMORY.FILL`_instr(memidx), var_0) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`MEMORY.COPY`_instr(memidx_1, memidx_2), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx_2, var_1) + -- fun_free_memidx: `%%`(memidx_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_102{memidx : uN, dataidx : uN, var_1 : free, var_0 : free}: + `%%`(`MEMORY.INIT`_instr(memidx, dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(dataidx, var_1) + -- fun_free_memidx: `%%`(memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_103{dataidx : uN, var_0 : free}: + `%%`(`DATA.DROP`_instr(dataidx), var_0) + -- fun_free_dataidx: `%%`(dataidx, var_0) + +;; ../../../../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*, free : free, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: + `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- if (|`var_2*`| = |`instr*`|) + -- (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) + -- wf_free: `%`(free) + -- if (free = var_1) +} + +;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec +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) + -- if (|`var_1*`| = |`instr*`|) + -- (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.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 +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 fun_free_tag: `%%`(tag, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + 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 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 fun_free_mem: `%%`(mem, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_mem_case_0{memtype : memtype, var_0 : free}: + `%%`(MEMORY_mem(memtype), var_0) + -- fun_free_memtype: `%%`(memtype, var_0) + +;; ../../../../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 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 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_3 : free, `var_2*` : free*, var_1 : free, var_0 : free}: + `%%`(FUNC_func(typeidx, local#1*{local#1 <- `local*`}, expr), var_0 +++ var_1 +++ var_3[LOCALS_free = []]) + -- fun_free_block: `%%`(expr, var_3) + -- if (|`var_2*`| = |`local*`|) + -- (fun_free_local: `%%`(local, var_2))*{var_2 <- `var_2*`, local <- `local*`} + -- fun_free_list: `%%`(var_2*{var_2 <- `var_2*`}, var_1) + -- fun_free_typeidx: `%%`(typeidx, 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_1 : free, var_0 : free}: + `%%`(ACTIVE_datamode(memidx, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_memidx: `%%`(memidx, 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 []}) + -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_data: `%%`(data, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + 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 +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_1 : free, var_0 : free}: + `%%`(ACTIVE_elemmode(tableidx, expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(expr, var_1) + -- fun_free_tableidx: `%%`(tableidx, 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 []}) + -- wf_free: `%`({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 []}) + -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) + +;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec +relation fun_free_elem: `%%`(elem, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + 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) + -- if (|`var_2*`| = |`expr*`|) + -- (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 +relation fun_free_start: `%%`(start, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_start_case_0{funcidx : uN, var_0 : free}: + `%%`(START_start(funcidx), var_0) + -- fun_free_funcidx: `%%`(funcidx, var_0) + +;; ../../../../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 fun_free_export: `%%`(export, free) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec + rule fun_free_export_case_0{name : name, externidx : externidx, var_0 : free}: + `%%`(EXPORT_export(name, externidx), var_0) + -- fun_free_externidx: `%%`(externidx, var_0) + +;; ../../../../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_21*` : free*, var_20 : free, `var_19*` : free*, var_18 : free, `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_8 +++ var_10 +++ var_12 +++ var_14 +++ var_16 +++ var_18 +++ var_20) + -- if (|`var_21*`| = |`export*`|) + -- (fun_free_export: `%%`(export, var_21))*{var_21 <- `var_21*`, export <- `export*`} + -- fun_free_list: `%%`(var_21*{var_21 <- `var_21*`}, var_20) + -- if (|`var_19*`| = |`import*`|) + -- (fun_free_import: `%%`(import, var_19))*{var_19 <- `var_19*`, import <- `import*`} + -- fun_free_list: `%%`(var_19*{var_19 <- `var_19*`}, var_18) + -- if ((`var_17?` = ?()) <=> (`start?` = ?())) + -- (fun_free_start: `%%`(start, var_17))?{var_17 <- `var_17?`, start <- `start?`} + -- fun_free_opt: `%%`(var_17?{var_17 <- `var_17?`}, var_16) + -- if (|`var_15*`| = |`elem*`|) + -- (fun_free_elem: `%%`(elem, var_15))*{var_15 <- `var_15*`, elem <- `elem*`} + -- fun_free_list: `%%`(var_15*{var_15 <- `var_15*`}, var_14) + -- if (|`var_13*`| = |`data*`|) + -- (fun_free_data: `%%`(data, var_13))*{var_13 <- `var_13*`, data <- `data*`} + -- fun_free_list: `%%`(var_13*{var_13 <- `var_13*`}, var_12) + -- if (|`var_11*`| = |`func*`|) + -- (fun_free_func: `%%`(func, var_11))*{var_11 <- `var_11*`, func <- `func*`} + -- fun_free_list: `%%`(var_11*{var_11 <- `var_11*`}, var_10) + -- if (|`var_9*`| = |`table*`|) + -- (fun_free_table: `%%`(table, var_9))*{var_9 <- `var_9*`, table <- `table*`} + -- fun_free_list: `%%`(var_9*{var_9 <- `var_9*`}, var_8) + -- if (|`var_7*`| = |`mem*`|) + -- (fun_free_mem: `%%`(mem, var_7))*{var_7 <- `var_7*`, mem <- `mem*`} + -- fun_free_list: `%%`(var_7*{var_7 <- `var_7*`}, var_6) + -- if (|`var_5*`| = |`global*`|) + -- (fun_free_global: `%%`(global, var_5))*{var_5 <- `var_5*`, global <- `global*`} + -- fun_free_list: `%%`(var_5*{var_5 <- `var_5*`}, var_4) + -- if (|`var_3*`| = |`tag*`|) + -- (fun_free_tag: `%%`(tag, var_3))*{var_3 <- `var_3*`, tag <- `tag*`} + -- fun_free_list: `%%`(var_3*{var_3 <- `var_3*`}, var_2) + -- if (|`var_1*`| = |`type*`|) + -- (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 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) + -- if (|`var_1*`| = |`func*`|) + -- (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 = + | 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 +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.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.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, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: + `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- fun_clos_deftypes: `%%`(dt#3*{dt#3 <- `dt*`}, var_1) + -- fun_subst_all_deftype: `%%%`(dt_n, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + -- if (dt'#1*{dt'#1 <- `dt'*`} = var_1) +} + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +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, `dt*` : deftype*, var_1 : deftype*, var_0 : valtype}: + `%%%`(C, t, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_valtype: `%%%`(t, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#4*{dt#4 <- `dt*`} = var_1) + +;; ../../../../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, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: + `%%%`(C, dt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_deftype: `%%%`(dt, $typeuse_deftype(dt')*{dt' <- `dt'*`}, var_0) + -- if (dt'#2*{dt'#2 <- `dt'*`} = var_1) + +;; ../../../../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 + rule fun_clos_tagtype_case_0{C : context, jt : typeuse, `dt*` : deftype*, var_1 : deftype*, var_0 : tagtype}: + `%%%`(C, jt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_tagtype: `%%%`(jt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#5*{dt#5 <- `dt*`} = var_1) + +;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec +relation fun_clos_externtype: `%%%`(context, externtype, externtype) + ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec + rule fun_clos_externtype_case_0{C : context, xt : externtype, `dt*` : deftype*, var_1 : deftype*, var_0 : externtype}: + `%%%`(C, xt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_externtype: `%%%`(xt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#6*{dt#6 <- `dt*`} = var_1) + +;; ../../../../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, `dt*` : deftype*, var_1 : deftype*, var_0 : moduletype}: + `%%%`(C, mmt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_moduletype: `%%%`(mmt, $typeuse_deftype(dt)*{dt <- `dt*`}, var_0) + -- if (dt#7*{dt#7 <- `dt*`} = var_1) + +;; ../../../../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*, var_0 : subtype}: + `%~~%`(deftype, comptype) + -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, comptype)) + -- if (var_0 = 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) + ;; ../../../../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 +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 + rule fun_unrollht__case_1{C : context, typeidx : uN, var_0 : subtype}: + `%%%`(C, _IDX_heaptype(typeidx), var_0) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) + -- fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(typeidx).0], var_0) + + ;; ../../../../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 +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, $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, $heaptype_typeuse(typeuse)) + -- wf_context: `%`(C) + -- wf_typeuse: `%`(typeuse) + -- Typeuse_ok: `%|-%:OK`(C, 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)) + -- wf_context: `%`(C) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), heaptype)) + -- Heaptype_ok: `%|-%:OK`(C, 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, $valtype_numtype(numtype)) + -- wf_context: `%`(C) + -- Numtype_ok: `%|-%:OK`(C, numtype) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:38.1-40.35 + rule vec{C : context, vectype : vectype}: + `%|-%:OK`(C, $valtype_vectype(vectype)) + -- wf_context: `%`(C) + -- Vectype_ok: `%|-%:OK`(C, vectype) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:42.1-44.35 + rule ref{C : context, reftype : reftype}: + `%|-%:OK`(C, $valtype_reftype(reftype)) + -- wf_context: `%`(C) + -- wf_reftype: `%`(reftype) + -- Reftype_ok: `%|-%:OK`(C, 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)) + -- wf_context: `%`(C) + -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) + -- if (C.TYPES_context[$proj_uN_0(typeidx).0] = dt) + + ;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_subtype: `%`(st) + -- wf_typeuse: `%`(REC_typeuse(i)) + -- if (i < |C.RECS_context|) + -- if (C.RECS_context[i] = st) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:114.1-116.35 + rule deftype{C : context, deftype : deftype}: + `%|-%:OK`(C, $typeuse_deftype(deftype)) + -- wf_context: `%`(C) + -- Deftype_ok: `%|-%:OK`(C, deftype) + +;; ../../../../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*`})) + -- wf_context: `%`(C) + -- (wf_valtype: `%`(t))*{t <- `t*`} + -- (Valtype_ok: `%|-%:OK`(C, 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)) + -- wf_context: `%`(C) + -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), storagetype)) + -- Storagetype_ok: `%|-%:OK`(C, 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, $storagetype_valtype(valtype)) + -- wf_context: `%`(C) + -- wf_valtype: `%`(valtype) + -- Valtype_ok: `%|-%:OK`(C, valtype) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:126.1-128.37 + rule pack{C : context, packtype : packtype}: + `%|-%:OK`(C, $storagetype_packtype(packtype)) + -- wf_context: `%`(C) + -- Packtype_ok: `%|-%:OK`(C, packtype) + +;; ../../../../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*`}))) + -- wf_context: `%`(C) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) + -- (Fieldtype_ok: `%|-%:OK`(C, 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)) + -- wf_context: `%`(C) + -- wf_comptype: `%`(ARRAY_comptype(fieldtype)) + -- Fieldtype_ok: `%|-%:OK`(C, 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*`}))) + -- wf_context: `%`(C) + -- wf_comptype: `%`(`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*`})) + +;; ../../../../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**, `var_0*` : subtype*}: + `%|-%:%`(C, SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype), OK_oktypenat(i)) + -- wf_context: `%`(C) + -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse*{typeuse <- `typeuse*`}, comptype)) + -- if (|`comptype'*`| = |`typeuse'**`|) + -- (wf_subtype: `%`(SUB_subtype(?(), typeuse'*{typeuse' <- `typeuse'*`}, comptype')))*{comptype' <- `comptype'*`, `typeuse'*` <- `typeuse'**`} + -- if (|typeuse*{typeuse <- `typeuse*`}| <= 1) + -- (Typeuse_ok: `%|-%:OK`(C, typeuse))*{typeuse <- `typeuse*`} + -- (if $before(typeuse, i))*{typeuse <- `typeuse*`} + -- if (|`var_0*`| = |`comptype'*`|) + -- if (|`var_0*`| = |`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'*`} + -- if (|`var_0*`| = |`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) + ;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_subtype: `%`(subtype_1) + -- (wf_subtype: `%`(subtype))*{subtype <- `subtype*`} + -- Subtype_ok2: `%|-%:%`(C, subtype_1, OK_oktypenat(i)) + -- Rectype_ok2: `%|-%:%`(C, REC_rectype(`%`_list(subtype*{subtype <- `subtype*`})), OK_oktypenat((i + 1))) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS subtype^n{subtype <- `subtype*`}}) + -- 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) + +;; ../../../../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*`}))) + -- 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*`}))) + -- if (|`ft_1*`| = |`ft_2*`|) + -- (Fieldtype_sub: `%|-%<:%`(C, ft_1, ft_2))*{ft_1 <- `ft_1*`, 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)) + -- wf_context: `%`(C) + -- wf_comptype: `%`(ARRAY_comptype(ft_1)) + -- wf_comptype: `%`(ARRAY_comptype(ft_2)) + -- Fieldtype_sub: `%|-%<:%`(C, ft_1, 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*`}))) + -- 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*`}))) + -- 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*`})) + +;; ../../../../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, var_1 : deftype, var_0 : deftype}: + `%|-%<:%`(C, deftype_1, deftype_2) + -- wf_context: `%`(C) + -- if (var_0 = var_1) + -- 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, var_0 : subtype}: + `%|-%<:%`(C, deftype_1, deftype_2) + -- wf_context: `%`(C) + -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- if (var_0 = 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)) + -- 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) + ;; ../../../../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) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(heaptype_1) + -- wf_heaptype: `%`(heaptype_2) + -- wf_heaptype: `%`(heaptype') + -- Heaptype_ok: `%|-%:OK`(C, heaptype') + -- Heaptype_sub: `%|-%<:%`(C, heaptype_1, heaptype') + -- Heaptype_sub: `%|-%<:%`(C, heaptype', heaptype_2) + + ;; ../../../../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, $heaptype_deftype(deftype), STRUCT_heaptype) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(STRUCT_heaptype) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(fieldtype*{fieldtype <- `fieldtype*`}))) + -- Expand: `%~~%`(deftype, 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, $heaptype_deftype(deftype), ARRAY_heaptype) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(ARRAY_heaptype) + -- wf_comptype: `%`(ARRAY_comptype(fieldtype)) + -- Expand: `%~~%`(deftype, 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, $heaptype_deftype(deftype), FUNC_heaptype) + -- 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*`}))) + -- Expand: `%~~%`(deftype, `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, $heaptype_deftype(deftype_1), $heaptype_deftype(deftype_2)) + -- wf_context: `%`(C) + -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) + + ;; ../../../../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) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(heaptype) + -- wf_heaptype: `%`(_IDX_heaptype(typeidx)) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) + -- Heaptype_sub: `%|-%<:%`(C, $heaptype_deftype(C.TYPES_context[$proj_uN_0(typeidx).0]), 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)) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(heaptype) + -- wf_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])) + + ;; ../../../../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) + -- 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*`})))) + -- if (i < |C.RECS_context|) + -- if (C.RECS_context[i] = 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) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(REC_heaptype(i)) + -- wf_heaptype: `%`(ARRAY_heaptype) + -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, [], ARRAY_comptype(fieldtype))) + -- if (i < |C.RECS_context|) + -- if (C.RECS_context[i] = 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) + -- 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*`})))) + -- 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*`})))) + + ;; ../../../../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*`}|) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(REC_heaptype(i)) + -- wf_subtype: `%`(SUB_subtype(final?{final <- `final?`}, typeuse*{typeuse <- `typeuse*`}, ct)) + -- if (i < |C.RECS_context|) + -- if (C.RECS_context[i] = 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) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(heaptype) + -- wf_heaptype: `%`(NONE_heaptype) + -- wf_heaptype: `%`(ANY_heaptype) + -- wf_heaptype: `%`(BOT_heaptype) + -- Heaptype_sub: `%|-%<:%`(C, heaptype, ANY_heaptype) + -- if (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) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(heaptype) + -- wf_heaptype: `%`(NOFUNC_heaptype) + -- wf_heaptype: `%`(FUNC_heaptype) + -- wf_heaptype: `%`(BOT_heaptype) + -- Heaptype_sub: `%|-%<:%`(C, heaptype, FUNC_heaptype) + -- if (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) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(heaptype) + -- wf_heaptype: `%`(NOEXN_heaptype) + -- wf_heaptype: `%`(EXN_heaptype) + -- wf_heaptype: `%`(BOT_heaptype) + -- Heaptype_sub: `%|-%<:%`(C, heaptype, EXN_heaptype) + -- if (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) + -- wf_context: `%`(C) + -- wf_heaptype: `%`(heaptype) + -- wf_heaptype: `%`(NOEXTERN_heaptype) + -- wf_heaptype: `%`(EXTERN_heaptype) + -- wf_heaptype: `%`(BOT_heaptype) + -- Heaptype_sub: `%|-%<:%`(C, heaptype, EXTERN_heaptype) + -- if (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)) + -- wf_context: `%`(C) + -- wf_reftype: `%`(REF_reftype(?(), ht_1)) + -- wf_reftype: `%`(REF_reftype(?(), ht_2)) + -- Heaptype_sub: `%|-%<:%`(C, ht_1, 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)) + -- wf_context: `%`(C) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), ht_1)) + -- wf_reftype: `%`(REF_reftype(?(NULL_null), ht_2)) + -- Heaptype_sub: `%|-%<:%`(C, ht_1, 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, $valtype_numtype(numtype_1), $valtype_numtype(numtype_2)) + -- wf_context: `%`(C) + -- Numtype_sub: `%|-%<:%`(C, numtype_1, numtype_2) + + ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:118.1-120.46 + rule vec{C : context, vectype_1 : vectype, vectype_2 : vectype}: + `%|-%<:%`(C, $valtype_vectype(vectype_1), $valtype_vectype(vectype_2)) + -- wf_context: `%`(C) + -- Vectype_sub: `%|-%<:%`(C, vectype_1, vectype_2) + + ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec:122.1-124.46 + rule ref{C : context, reftype_1 : reftype, reftype_2 : reftype}: + `%|-%<:%`(C, $valtype_reftype(reftype_1), $valtype_reftype(reftype_2)) + -- wf_context: `%`(C) + -- wf_reftype: `%`(reftype_1) + -- wf_reftype: `%`(reftype_2) + -- Reftype_sub: `%|-%<:%`(C, reftype_1, 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*`})) + -- wf_context: `%`(C) + -- (wf_valtype: `%`(t_1))*{t_1 <- `t_1*`} + -- (wf_valtype: `%`(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*`} + +;; ../../../../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, $storagetype_valtype(valtype_1), $storagetype_valtype(valtype_2)) + -- wf_context: `%`(C) + -- wf_valtype: `%`(valtype_1) + -- wf_valtype: `%`(valtype_2) + -- Valtype_sub: `%|-%<:%`(C, valtype_1, 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, $storagetype_packtype(packtype_1), $storagetype_packtype(packtype_2)) + -- wf_context: `%`(C) + -- Packtype_sub: `%|-%<:%`(C, packtype_1, packtype_2) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt_1)) + -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt_2)) + -- Storagetype_sub: `%|-%<:%`(C, zt_1, 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)) + -- wf_context: `%`(C) + -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt_1)) + -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt_2)) + -- Storagetype_sub: `%|-%<:%`(C, zt_1, zt_2) + -- Storagetype_sub: `%|-%<:%`(C, zt_2, zt_1) +} + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_localtype: `%`(`%%`_localtype(init, t)) + -- Valtype_ok: `%|-%:OK`(C, 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*`}))) + -- 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*`}))) + -- 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*`} + +;; ../../../../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}: + `%~~_%%`($typeuse_deftype(deftype), C, comptype) + -- wf_context: `%`(C) + -- wf_comptype: `%`(comptype) + -- Expand: `%~~%`(deftype, comptype) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule typeidx{typeidx : typeidx, C : context, comptype : comptype}: + `%~~_%%`(_IDX_typeuse(typeidx), C, comptype) + -- wf_context: `%`(C) + -- wf_comptype: `%`(comptype) + -- wf_typeuse: `%`(_IDX_typeuse(typeidx)) + -- if ($proj_uN_0(typeidx).0 < |C.TYPES_context|) + -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(typeidx).0], comptype) + +;; ../../../../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**, `var_0*` : subtype*}: + `%|-%:%`(C, SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype), OK_oktypeidx(x_0)) + -- wf_context: `%`(C) + -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- `x*`}, comptype)) + -- wf_oktypeidx: `%`(OK_oktypeidx(x_0)) + -- if (|`comptype'*`| = |`yy**`|) + -- (wf_subtype: `%`(SUB_subtype(?(), yy*{yy <- `yy*`}, comptype')))*{comptype' <- `comptype'*`, `yy*` <- `yy**`} + -- if (|x*{x <- `x*`}| <= 1) + -- (if ($proj_uN_0(x).0 < $proj_uN_0(x_0).0))*{x <- `x*`} + -- if (|`var_0*`| = |`comptype'*`|) + -- if (|`var_0*`| = |`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'*`} + -- if (|`var_0*`| = |`x*`|) + -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- `x*`} + -- (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 { + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_subtype: `%`(subtype_1) + -- (wf_subtype: `%`(subtype))*{subtype <- `subtype*`} + -- wf_oktypeidx: `%`(OK_oktypeidx(x)) + -- wf_oktypeidx: `%`(OK_oktypeidx(`%`_typeidx(($proj_uN_0(x).0 + 1)))) + -- Subtype_ok: `%|-%:%`(C, subtype_1, OK_oktypeidx(x)) + -- Rectype_ok: `%|-%:%`(C, REC_rectype(`%`_list(subtype*{subtype <- `subtype*`})), OK_oktypeidx(`%`_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 _{C : context, n : n, `m?` : m?, k : nat}: + `%|-%:%`(C, `[%..%]`_limits(`%`_u64(n), `%`_u64(m)?{m <- `m?`}), k) + -- wf_context: `%`(C) + -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n), `%`_u64(m)?{m <- `m?`})) + -- if (n <= k) + -- (if ((n <= m) /\ (m <= k)))?{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) + -- wf_context: `%`(C) + -- wf_typeuse: `%`(typeuse) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), `%`_resulttype(t_2*{t_2 <- `t_2*`}))) + -- 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*`}))) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), t)) + -- Valtype_ok: `%|-%:OK`(C, 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)) + -- wf_context: `%`(C) + -- wf_memtype: `%`(`%%PAGE`_memtype(addrtype, limits)) + -- Limits_ok: `%|-%:%`(C, limits, (2 ^ ((($size($numtype_addrtype(addrtype)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_tabletype: `%`(`%%%`_tabletype(addrtype, limits, reftype)) + -- Limits_ok: `%|-%:%`(C, limits, ((((2 ^ $size($numtype_addrtype(addrtype))) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) + -- Reftype_ok: `%|-%:OK`(C, 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)) + -- wf_context: `%`(C) + -- wf_externtype: `%`(TAG_externtype(tagtype)) + -- Tagtype_ok: `%|-%:OK`(C, tagtype) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule global{C : context, globaltype : globaltype}: + `%|-%:OK`(C, GLOBAL_externtype(globaltype)) + -- wf_context: `%`(C) + -- wf_externtype: `%`(GLOBAL_externtype(globaltype)) + -- Globaltype_ok: `%|-%:OK`(C, globaltype) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule mem{C : context, memtype : memtype}: + `%|-%:OK`(C, MEM_externtype(memtype)) + -- wf_context: `%`(C) + -- wf_externtype: `%`(MEM_externtype(memtype)) + -- Memtype_ok: `%|-%:OK`(C, memtype) + + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec + rule table{C : context, tabletype : tabletype}: + `%|-%:OK`(C, TABLE_externtype(tabletype)) + -- wf_context: `%`(C) + -- wf_externtype: `%`(TABLE_externtype(tabletype)) + -- Tabletype_ok: `%|-%:OK`(C, 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)) + -- 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*`}))) + -- 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*`}))) + +;; ../../../../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*`}))) + -- 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*`} + -- 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*`} + +;; ../../../../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?`})) + -- 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?`})) + -- if (n_1 >= n_2) + -- (if (m_1 <= 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), ?())) + -- wf_context: `%`(C) + -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_1), ?())) + -- wf_limits: `%`(`[%..%]`_limits(`%`_u64(n_2), ?())) + -- if (n_1 >= 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, $typeuse_deftype(deftype_1), $typeuse_deftype(deftype_2)) + -- wf_context: `%`(C) + -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) + -- Deftype_sub: `%|-%<:%`(C, deftype_2, deftype_1) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_globaltype: `%`(`%%`_globaltype(?(), valtype_1)) + -- wf_globaltype: `%`(`%%`_globaltype(?(), valtype_2)) + -- Valtype_sub: `%|-%<:%`(C, valtype_1, 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)) + -- wf_context: `%`(C) + -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), valtype_1)) + -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), valtype_2)) + -- Valtype_sub: `%|-%<:%`(C, valtype_1, valtype_2) + -- Valtype_sub: `%|-%<:%`(C, valtype_2, valtype_1) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_memtype: `%`(`%%PAGE`_memtype(addrtype, limits_1)) + -- wf_memtype: `%`(`%%PAGE`_memtype(addrtype, limits_2)) + -- Limits_sub: `%|-%<:%`(C, limits_1, 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)) + -- wf_context: `%`(C) + -- wf_tabletype: `%`(`%%%`_tabletype(addrtype, limits_1, reftype_1)) + -- wf_tabletype: `%`(`%%%`_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) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_externtype: `%`(TAG_externtype(tagtype_1)) + -- wf_externtype: `%`(TAG_externtype(tagtype_2)) + -- Tagtype_sub: `%|-%<:%`(C, tagtype_1, 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)) + -- wf_context: `%`(C) + -- wf_externtype: `%`(GLOBAL_externtype(globaltype_1)) + -- wf_externtype: `%`(GLOBAL_externtype(globaltype_2)) + -- Globaltype_sub: `%|-%<:%`(C, globaltype_1, 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)) + -- wf_context: `%`(C) + -- wf_externtype: `%`(MEM_externtype(memtype_1)) + -- wf_externtype: `%`(MEM_externtype(memtype_2)) + -- Memtype_sub: `%|-%<:%`(C, memtype_1, 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)) + -- wf_context: `%`(C) + -- wf_externtype: `%`(TABLE_externtype(tabletype_1)) + -- wf_externtype: `%`(TABLE_externtype(tabletype_2)) + -- Tabletype_sub: `%|-%<:%`(C, tabletype_1, tabletype_2) + + ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec + rule func{C : context, deftype_1 : deftype, deftype_2 : deftype}: + `%|-%<:%`(C, FUNC_externtype($typeuse_deftype(deftype_1)), FUNC_externtype($typeuse_deftype(deftype_2))) + -- wf_context: `%`(C) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(deftype_1))) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(deftype_2))) + -- Deftype_sub: `%|-%<:%`(C, deftype_1, deftype_2) + +;; ../../../../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?`})))) + -- wf_context: `%`(C) + -- wf_blocktype: `%`(_RESULT_blocktype(valtype?{valtype <- `valtype?`})) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(valtype?{valtype <- `valtype?`})))) + -- (Valtype_ok: `%|-%:OK`(C, 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*`}))) + -- 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*`}))) + -- 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*`}))) + +;; ../../../../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*, var_0 : deftype?}: + `%|-%:OK`(C, CATCH_catch(x, l)) + -- wf_context: `%`(C) + -- wf_catch: `%`(CATCH_catch(x, l)) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) + -- if (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_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(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) + + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec + rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*, var_0 : deftype?}: + `%|-%:OK`(C, CATCH_REF_catch(x, l)) + -- wf_context: `%`(C) + -- wf_catch: `%`(CATCH_REF_catch(x, l)) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) + -- if (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_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(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) + + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec + rule catch_all{C : context, l : labelidx}: + `%|-%:OK`(C, CATCH_ALL_catch(l)) + -- wf_context: `%`(C) + -- wf_catch: `%`(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]) + + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec + rule catch_all_ref{C : context, l : labelidx}: + `%|-%:OK`(C, CATCH_ALL_REF_catch(l)) + -- wf_context: `%`(C) + -- wf_catch: `%`(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]) + +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +relation fun_default__before_fun_default__case_7: `%`(valtype) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_6{ht : heaptype}: + `%`(REF_valtype(?(), ht)) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_5{ht : heaptype}: + `%`(REF_valtype(?(NULL_null), ht)) + -- wf_val: `%`(`REF.NULL_ADDR`_val) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_4: + `%`(V128_valtype) + -- wf_val: `%`(VCONST_val(V128_vectype, `%`_vec_(0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_3{var_0 : fN}: + `%`(F64_valtype) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_2{var_0 : fN}: + `%`(F32_valtype) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_1: + `%`(I64_valtype) + -- 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 + rule fun_default__case_0: + `%`(I32_valtype) + -- 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 +relation fun_default_: `%%`(valtype, val??) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_0: + `%%`(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 + rule fun_default__case_1: + `%%`(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 + rule fun_default__case_2{var_0 : fN}: + `%%`(F32_valtype, ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_3{var_0 : fN}: + `%%`(F64_valtype, ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_4: + `%%`(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 + rule fun_default__case_5{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 + rule fun_default__case_6{ht : heaptype}: + `%%`(REF_valtype(?(), ht), ?(?())) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_7{x0 : valtype}: + `%%`(x0, ?()) + -- ~ fun_default__before_fun_default__case_7: `%`(x0) + +;; ../../../../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, var_0 : val??}: + `|-%DEFAULTABLE`(t) + -- wf_valtype: `%`(t) + -- if (var_0 =/= ?()) + -- if (!(var_0) =/= ?()) + -- fun_default_: `%%`(t, var_0) + +;; ../../../../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) + -- wf_memarg: `%`({ALIGN `%`_u32(n), OFFSET `%`_u64(m)}) + -- if (((2 ^ n) : nat <:> rat) <= ((N : nat <:> rat) / (8 : nat <:> rat))) + -- if (m < (2 ^ $size($numtype_addrtype(at)))) + +;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec +relation fun_is_packtype: `%%`(storagetype, bool) + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec + rule fun_is_packtype_case_0{zt : storagetype, var_0 : valtype}: + `%%`(zt, (zt =/= $storagetype_valtype(var_0))) + -- fun_unpack: `%%`(zt, var_0) + +;; ../../../../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*`}))) + -- wf_context: `%`(C) + -- wf_instr: `%`(UNREACHABLE_instr) + -- wf_instrtype: `%`(`%->_%%`_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*`}))) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(DROP_instr) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) + -- Valtype_ok: `%|-%:OK`(C, t) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(SELECT_instr(?([t]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) + -- Valtype_ok: `%|-%:OK`(C, 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]))) + -- wf_context: `%`(C) + -- wf_valtype: `%`(t') + -- wf_instr: `%`(SELECT_instr(?())) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t t I32_valtype]), [], `%`_resulttype([t]))) + -- Valtype_ok: `%|-%:OK`(C, t) + -- Valtype_sub: `%|-%<:%`(C, t, t') + -- if ((t' = $valtype_numtype(numtype)) \/ (t' = $valtype_vectype(vectype))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- wf_context: `%`(C) + -- wf_instr: `%`(BR_IF_instr(l)) + -- wf_instrtype: `%`(`%->_%%`_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*`}) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- (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*`}))) + + ;; ../../../../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)]))) + -- 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)]))) + -- 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) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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)])) + + ;; ../../../../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, var_0 : 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(var_0)]))) + -- wf_context: `%`(C) + -- wf_reftype: `%`(rt) + -- wf_instr: `%`(BR_ON_CAST_instr(l, rt_1, rt_2)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t*{t <- `t*`} ++ [$valtype_reftype(var_0)]))) + -- 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) + -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) + -- Reftype_sub: `%|-%<:%`(C, rt_2, rt) + -- fun_diffrt: `%%%`(rt_1, rt_2, var_0) + + ;; ../../../../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, var_0 : 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)]))) + -- 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*`} ++ [$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) + -- Reftype_sub: `%|-%<:%`(C, rt_2, rt_1) + -- Reftype_sub: `%|-%<:%`(C, var_0, rt) + -- fun_diffrt: `%%%`(rt_1, rt_2, var_0) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- wf_context: `%`(C) + -- wf_instr: `%`(CALL_INDIRECT_instr(x, _IDX_typeuse(y))) + -- 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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- 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*`})) + -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*`}))) + -- 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*`}))) + -- 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*`})) + -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*`} ++ [$valtype_addrtype(at)]), [], `%`_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*`} ++ [$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*`}))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_3*{t_3 <- `t_3*`}), [], `%`_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*`})) + -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*, var_0 : deftype?}: + `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`} ++ t*{t <- `t*`}), [], `%`_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*`}))) + -- if (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_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*`}))) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*`}))) + -- 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*`}))) + -- 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*`} + + ;; ../../../../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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`REF.NULL`_instr(ht)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(NULL_null), ht)]))) + -- Heaptype_ok: `%|-%:OK`(C, 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))]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`REF.FUNC`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_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) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`REF.IS_NULL`_instr) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([I32_valtype]))) + -- Heaptype_ok: `%|-%:OK`(C, ht) + + ;; ../../../../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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), ht)]), [], `%`_resulttype([REF_valtype(?(), ht)]))) + -- Heaptype_ok: `%|-%:OK`(C, 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([$valtype_reftype(rt')]), [], `%`_resulttype([I32_valtype]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`REF.TEST`_instr(rt)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([I32_valtype]))) + -- Reftype_ok: `%|-%:OK`(C, rt) + -- Reftype_ok: `%|-%:OK`(C, rt') + -- Reftype_sub: `%|-%<:%`(C, rt, rt') + + ;; ../../../../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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`REF.CAST`_instr(rt)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_reftype(rt')]), [], `%`_resulttype([$valtype_reftype(rt)]))) + -- Reftype_ok: `%|-%:OK`(C, rt) + -- Reftype_ok: `%|-%:OK`(C, rt') + -- Reftype_sub: `%|-%<:%`(C, rt, rt') + + ;; ../../../../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?*, `var_0*` : valtype*}: + `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`STRUCT.NEW`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- 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 (|`var_0*`| = |`zt*`|) + -- (fun_unpack: `%%`(zt, var_0))*{var_0 <- `var_0*`, 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*, `var_0*` : valtype*}: + `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- 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*`}))) + -- 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`(var_0))*{var_0 <- `var_0*`} + -- if (|`var_0*`| = |`zt*`|) + -- (fun_unpack: `%%`(zt, var_0))*{var_0 <- `var_0*`, 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?, var_1 : bool, var_0 : valtype}: + `%|-%:%`(C, `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([var_0]))) + -- 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([var_0]))) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut?{mut <- `mut?`}, 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?`} =/= ?()) <=> var_1) + -- fun_is_packtype: `%%`(zt, var_1) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../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*, var_0 : valtype}: + `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) var_0]), [], `%`_resulttype([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`STRUCT.SET`_instr(x, i)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) var_0]), [], `%`_resulttype([]))) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) + -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), 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), zt)) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:272.1-274.43 + rule `array.new`{C : context, x : idx, zt : storagetype, `mut?` : mut?, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([var_0 I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([var_0 I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../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, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- 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))) + -- 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`(var_0) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../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?, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(n)), `%->_%%`_instrtype(`%`_resulttype(var_0^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(var_0^n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../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))]))) + -- 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?`}, $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?`}, $storagetype_reftype(rt)))) + -- if ($proj_uN_0(y).0 < |C.ELEMS_context|) + -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], 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, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- 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))) + -- 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 ((var_0 = $valtype_numtype(numtype)) \/ (var_0 = $valtype_vectype(vectype))) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) + -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../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?, var_1 : bool, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([var_0]))) + -- 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([var_0]))) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{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 <- `mut?`}, zt))) + -- if ((sx?{sx <- `sx?`} =/= ?()) <=> var_1) + -- fun_is_packtype: `%%`(zt, var_1) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:301.1-303.42 + rule `array.set`{C : context, x : idx, zt : storagetype, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0]), [], `%`_resulttype([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`ARRAY.SET`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0]), [], `%`_resulttype([]))) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../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, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0 I32_valtype]), [], `%`_resulttype([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`ARRAY.FILL`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0 I32_valtype]), [], `%`_resulttype([]))) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../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([]))) + -- 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))) + -- 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) + + ;; ../../../../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([]))) + -- 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))) + -- 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) + + ;; ../../../../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, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- 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))) + -- 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 ((var_0 = $valtype_numtype(numtype)) \/ (var_0 = $valtype_vectype(vectype))) + -- if ($proj_uN_0(y).0 < |C.DATAS_context|) + -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- fun_unpack: `%%`(zt, var_0) + + ;; ../../../../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)]))) + -- 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)]))) + -- if (null_1?{null_1 <- `null_1?`} = null_2?{null_2 <- `null_2?`}) + + ;; ../../../../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)]))) + -- 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)]))) + -- if (null_1?{null_1 <- `null_1?`} = null_2?{null_2 <- `null_2?`}) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`LOCAL.GET`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) + -- wf_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)) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`LOCAL.SET`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([]))) + -- wf_localtype: `%`(`%%`_localtype(init, t)) + -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) + -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`LOCAL.TEE`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [x], `%`_resulttype([t]))) + -- wf_localtype: `%`(`%%`_localtype(init, t)) + -- if ($proj_uN_0(x).0 < |C.LOCALS_context|) + -- if (C.LOCALS_context[$proj_uN_0(x).0] = `%%`_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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) + -- wf_globaltype: `%`(`%%`_globaltype(mut?{mut <- `mut?`}, t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`GLOBAL.SET`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([t]), [], `%`_resulttype([]))) + -- wf_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)) + + ;; ../../../../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)]))) + -- 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)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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([]))) + -- 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)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`TABLE.SIZE`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- wf_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)) + + ;; ../../../../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)]))) + -- 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)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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([]))) + -- 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)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + -- if (C.TABLES_context[$proj_uN_0(x).0] = `%%%`_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([]))) + -- 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)) + -- 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) + + ;; ../../../../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([]))) + -- 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)) + -- 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) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- wf_reftype: `%`(rt) + -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + -- if ($proj_uN_0(x).0 < |C.ELEMS_context|) + -- if (C.ELEMS_context[$proj_uN_0(x).0] = rt) + + ;; ../../../../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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`MEMORY.SIZE`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`MEMORY.GROW`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_addrtype(at)]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`MEMORY.FILL`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype $valtype_addrtype(at)]), [], `%`_resulttype([]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + -- if (C.MEMS_context[$proj_uN_0(x).0] = `%%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([]))) + -- 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_memtype: `%`(`%%PAGE`_memtype(at_1, lim_1)) + -- wf_memtype: `%`(`%%PAGE`_memtype(at_2, lim_2)) + -- 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)) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`MEMORY.INIT`_instr(x, y)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) I32_valtype I32_valtype]), [], `%`_resulttype([]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`DATA.DROP`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([]))) + -- if ($proj_uN_0(x).0 < |C.DATAS_context|) + -- if (C.DATAS_context[$proj_uN_0(x).0] = OK_datatype) + + ;; ../../../../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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(LOAD_instr(nt, ?(), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([$valtype_numtype(nt)]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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)) + + ;; ../../../../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)]))) + -- wf_context: `%`(C) + -- 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)) + -- 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) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(STORE_instr(nt, ?(), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) $valtype_numtype(nt)]), [], `%`_resulttype([]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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)) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- 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)) + -- 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) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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)) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(`SHAPE%X%_%`_vloadop_(`%`_sz(M), N, sx)), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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)) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at)]), [], `%`_resulttype([V128_valtype]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VLOAD_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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))) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VSTORE_instr(V128_vectype, x, memarg)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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)) + + ;; ../../../../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([]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, memarg, i)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$valtype_addrtype(at) V128_valtype]), [], `%`_resulttype([]))) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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))) + + ;; ../../../../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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(CONST_instr(nt, c_nt)) + -- 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([$valtype_numtype(nt)]), [], `%`_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)]))) + + ;; ../../../../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)]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(BINOP_instr(nt, binop_nt)) + -- 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([$valtype_numtype(nt)]), [], `%`_resulttype([I32_valtype]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(TESTOP_instr(nt, testop_nt)) + -- 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([$valtype_numtype(nt) $valtype_numtype(nt)]), [], `%`_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]))) + + ;; ../../../../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)]))) + -- 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)]))) + + ;; ../../../../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*, var_0 : dim}: + `%|-%:%`(C, VSHUFFLE_instr(sh, i*{i <- `i*`}), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VSHUFFLE_instr(sh, i*{i <- `i*`})) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) + -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0(var_0).0)))*{i <- `i*`} + -- fun_dim: `%%`($proj_bshape_0(sh).0, var_0) + + ;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VSPLAT_instr(sh)) + -- 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, var_0 : dim}: + `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx?{sx <- `sx?`}, i)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) + -- if ($proj_uN_0(i).0 < $proj_dim_0(var_0).0) + -- fun_dim: `%%`(sh, var_0) + + ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:591.1-593.21 + rule vreplace_lane{C : context, sh : shape, i : laneidx, var_0 : dim}: + `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) + -- if ($proj_uN_0(i).0 < $proj_dim_0(var_0).0) + -- fun_dim: `%%`(sh, var_0) + + ;; ../../../../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*, 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*`}))) + -- 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*`}))) + -- if (|`init*`| = |`t*`|) + -- (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*`}))) + -- 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*`| = |`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 (var_0 =/= ?()) + -- 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*`}))) + -- 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}: + `%|-%:%`(C, instr*{instr <- `instr*`}, it') + -- wf_context: `%`(C) + -- (wf_instr: `%`(instr))*{instr <- `instr*`} + -- wf_instrtype: `%`(it') + -- wf_instrtype: `%`(it) + -- Instrs_ok: `%|-%:%`(C, instr*{instr <- `instr*`}, it) + -- Instrtype_sub: `%|-%<:%`(C, it, it') + -- Instrtype_ok: `%|-%:OK`(C, 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*`}))) + -- 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*`}))) + -- 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*`})) +} + +;; ../../../../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*`})) + -- wf_context: `%`(C) + -- (wf_instr: `%`(instr))*{instr <- `instr*`} + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t*{t <- `t*`}))) + -- Instrs_ok: `%|-%:%`(C, instr*{instr <- `instr*`}, `%->_%%`_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, var_0 : val??}: + `|-%NONDEFAULTABLE`(t) + -- wf_valtype: `%`(t) + -- if (var_0 =/= ?()) + -- if (!(var_0) = ?()) + -- fun_default_: `%%`(t, var_0) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) + -- wf_globaltype: `%`(`%%`_globaltype(?(), t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_globaltype(?(), t)) + + ;; ../../../../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)) + -- wf_context: `%`(C) + -- 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)) + -- 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)]) + +;; ../../../../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*`}) + -- wf_context: `%`(C) + -- (wf_instr: `%`(instr))*{instr <- `instr*`} + -- (Instr_const: `%|-%CONST`(C, 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) + -- wf_context: `%`(C) + -- (wf_instr: `%`(expr))*{expr <- expr} + -- wf_valtype: `%`(t) + -- Expr_ok: `%|-%:%`(C, expr, `%`_resulttype([t])) + -- Expr_const: `%|-%CONST`(C, expr) + +;; ../../../../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, var_0 : deftype*}: + `%|-%:%`(C, TYPE_type(rectype), dt*{dt <- `dt*`}) + -- 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)) + -- 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)) + -- 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, var_0 : tagtype}: + `%|-%:%`(C, TAG_tag(tagtype), var_0) + -- wf_context: `%`(C) + -- wf_tag: `%`(TAG_tag(tagtype)) + -- Tagtype_ok: `%|-%:OK`(C, tagtype) + -- fun_clos_tagtype: `%%%`(C, tagtype, var_0) + +;; ../../../../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) + -- wf_context: `%`(C) + -- wf_global: `%`(GLOBAL_global(globaltype, expr)) + -- wf_globaltype: `%`(`%%`_globaltype(?(MUT_mut), t)) + -- Globaltype_ok: `%|-%:OK`(C, globaltype) + -- if (globaltype = `%%`_globaltype(?(MUT_mut), t)) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, 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) + -- wf_context: `%`(C) + -- wf_mem: `%`(MEMORY_mem(memtype)) + -- Memtype_ok: `%|-%:OK`(C, 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) + -- wf_context: `%`(C) + -- wf_table: `%`(TABLE_table(tabletype, expr)) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, rt)) + -- Tabletype_ok: `%|-%:OK`(C, tabletype) + -- if (tabletype = `%%%`_tabletype(at, lim, rt)) + -- Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_reftype(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)) + -- wf_context: `%`(C) + -- wf_local: `%`(LOCAL_local(t)) + -- wf_localtype: `%`(`%%`_localtype(SET_init, t)) + -- Defaultable: `|-%DEFAULTABLE`(t) + + ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec + rule unset{C : context, t : valtype}: + `%|-%:%`(C, LOCAL_local(t), `%%`_localtype(UNSET_init, t)) + -- wf_context: `%`(C) + -- wf_local: `%`(LOCAL_local(t)) + -- wf_localtype: `%`(`%%`_localtype(UNSET_init, t)) + -- Nondefaultable: `|-%NONDEFAULTABLE`(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[$proj_uN_0(x).0]) + -- if ($proj_uN_0(x).0 < |C.TYPES_context|) + -- 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 []}) + -- 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*`})) + +;; ../../../../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) + -- wf_context: `%`(C) + -- wf_datamode: `%`(ACTIVE_datamode(x, expr)) + -- wf_memtype: `%`(`%%PAGE`_memtype(at, lim)) + -- 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)) + +;; ../../../../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) + -- wf_context: `%`(C) + -- wf_data: `%`(DATA_data(b*{b <- `b*`}, datamode)) + -- Datamode_ok: `%|-%:%`(C, datamode, OK_datatype) + +;; ../../../../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) + -- wf_context: `%`(C) + -- wf_reftype: `%`(rt) + -- wf_elemmode: `%`(ACTIVE_elemmode(x, expr)) + -- wf_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, expr, $valtype_addrtype(at)) + +;; ../../../../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) + -- wf_context: `%`(C) + -- wf_elem: `%`(ELEM_elem(elemtype, expr*{expr <- `expr*`}, elemmode)) + -- Reftype_ok: `%|-%:OK`(C, elemtype) + -- (Expr_ok_const: `%|-%:%CONST`(C, expr, $valtype_reftype(elemtype)))*{expr <- `expr*`} + -- Elemmode_ok: `%|-%:%`(C, elemmode, elemtype) + +;; ../../../../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)) + -- wf_context: `%`(C) + -- wf_start: `%`(START_start(x)) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype([]), `%`_resulttype([]))) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) + -- Expand: `%~~%`(C.FUNCS_context[$proj_uN_0(x).0], `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, var_0 : externtype}: + `%|-%:%`(C, IMPORT_import(name_1, name_2, xt), var_0) + -- wf_context: `%`(C) + -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) + -- Externtype_ok: `%|-%:OK`(C, 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)) + -- wf_context: `%`(C) + -- wf_externidx: `%`(TAG_externidx(x)) + -- wf_externtype: `%`(TAG_externtype(jt)) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) + -- if (C.TAGS_context[$proj_uN_0(x).0] = 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)) + -- wf_context: `%`(C) + -- wf_externidx: `%`(GLOBAL_externidx(x)) + -- wf_externtype: `%`(GLOBAL_externtype(gt)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = 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)) + -- wf_context: `%`(C) + -- wf_externidx: `%`(MEM_externidx(x)) + -- wf_externtype: `%`(MEM_externtype(mt)) + -- if ($proj_uN_0(x).0 < |C.MEMS_context|) + -- if (C.MEMS_context[$proj_uN_0(x).0] = 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)) + -- wf_context: `%`(C) + -- wf_externidx: `%`(TABLE_externidx(x)) + -- wf_externtype: `%`(TABLE_externtype(tt)) + -- if ($proj_uN_0(x).0 < |C.TABLES_context|) + -- if (C.TABLES_context[$proj_uN_0(x).0] = tt) + + ;; ../../../../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))) + -- wf_context: `%`(C) + -- wf_externidx: `%`(FUNC_externidx(x)) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(dt))) + -- if ($proj_uN_0(x).0 < |C.FUNCS_context|) + -- if (C.FUNCS_context[$proj_uN_0(x).0] = dt) + +;; ../../../../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) + -- wf_context: `%`(C) + -- wf_externtype: `%`(xt) + -- wf_export: `%`(EXPORT_export(name, externidx)) + -- Externidx_ok: `%|-%:%`(C, externidx, xt) + +;; ../../../../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*`}) + -- 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 []}) + -- 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*`}) +} + +;; ../../../../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*`}) + -- wf_context: `%`(C) + -- wf_context: `%`({TYPES dt_1*{dt_1 <- `dt_1*`}, TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- 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*`}) +} + +;; ../../../../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 +relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) + ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec + 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) + -- 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) + ;; ../../../../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*, 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) + -- 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*`})) + -- 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*`} = var_1) + -- 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*`})) + -- 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 + 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 +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 + 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][$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][$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 +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 +relation fun_signed_: `%%%`(N, nat, int) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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 + 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 +relation fun_inv_signed_: `%%%`(N, int, nat) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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 + 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 +relation fun_sx_before_fun_sx_case_7: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_6: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_5: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_4: + `%`(V128_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_sx: `%%`(storagetype, sx??) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_0: + `%%`(I32_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_1: + `%%`(I64_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_2: + `%%`(F32_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_3: + `%%`(F64_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_4: + `%%`(V128_storagetype, ?(?())) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_5: + `%%`(I8_storagetype, ?(?(S_sx))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_6: + `%%`(I16_storagetype, ?(?(S_sx))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_7{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_sx_before_fun_sx_case_7: `%`(x0) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_zero: `%%`(lanetype, lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_zero_case_0: + `%%`(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 + rule fun_zero_case_1: + `%%`(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 + rule fun_zero_case_2: + `%%`(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 + rule fun_zero_case_3: + `%%`(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 + rule fun_zero_case_4{var_0 : fN}: + `%%`(F32_lanetype, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_zero_case_5{var_0 : fN}: + `%%`(F64_lanetype, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + +;; ../../../../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) - ($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, 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 + +;; ../../../../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 +relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_iextend__case_0{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 + 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) + -- wf_uN: `%%`(N, `%`_uN(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 +relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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 + 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)))) + -- 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 + 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 + 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, ?()) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(N, $proj_uN_0(i_1).0, var_0) + -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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) + -- wf_uN: `%%`(N, `%`_uN(var_0)) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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 + 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)))) + -- 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 + 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 + 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))) + -- 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) + -- wf_uN: `%%`(N, `%`_uN(var_0)) + -- if ((j_1 = var_1) /\ (j_2 = var_2)) + +;; ../../../../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 ($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 ($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, 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 ($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 ($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, 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, var_2 : int, var_1 : int, var_0 : nat}(N, S_sx, i_1, i_2) = `%`_iN(var_0) + -- wf_uN: `%%`(N, `%`_uN(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, var_2 : int, var_1 : int, var_0 : nat}(N, S_sx, i_1, i_2) = `%`_iN(var_0) + -- wf_uN: `%%`(N, `%`_uN(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 + +;; ../../../../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 +relation fun_ieqz_: `%%%`(N, iN, u32) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_ieqz__case_0{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 +relation fun_inez_: `%%%`(N, iN, u32) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_inez__case_0{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, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 < var_1))) + -- wf_uN: `%%`(32, `%`_uN($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, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 > var_1))) + -- wf_uN: `%%`(32, `%`_uN($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, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 <= var_1))) + -- wf_uN: `%%`(32, `%`_uN($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, var_1 : int, var_0 : int}(N, S_sx, i_1, i_2) = `%`_u32($bool((var_0 >= var_1))) + -- wf_uN: `%%`(32, `%`_uN($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 +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 +relation fun_lpacknum_: `%%%`(lanetype, num_, lane_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_lpacknum__case_0{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 + rule fun_lpacknum__case_1{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 + rule fun_lpacknum__case_2{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 + rule fun_lpacknum__case_3{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 + rule fun_lpacknum__case_4{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 + rule fun_lpacknum__case_5{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 fun_cpacknum_: `%%%`(storagetype, lit_, lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cpacknum__case_0{c : lit_}: + `%%%`(I32_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cpacknum__case_1{c : lit_}: + `%%%`(I64_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cpacknum__case_2{c : lit_}: + `%%%`(F32_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cpacknum__case_3{c : lit_}: + `%%%`(F64_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cpacknum__case_4{c : lit_}: + `%%%`(V128_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cpacknum__case_5{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 + rule fun_cpacknum__case_6{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 fun_lunpacknum_: `%%%`(lanetype, lane_, num_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_lunpacknum__case_0{c : num_}: + `%%%`(I32_lanetype, mk_lane__0_lane_(I32_numtype, c), c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_lunpacknum__case_1{c : num_}: + `%%%`(I64_lanetype, mk_lane__0_lane_(I64_numtype, c), c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_lunpacknum__case_2{c : num_}: + `%%%`(F32_lanetype, mk_lane__0_lane_(F32_numtype, c), c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_lunpacknum__case_3{c : num_}: + `%%%`(F64_lanetype, mk_lane__0_lane_(F64_numtype, c), c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_lunpacknum__case_4{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 + rule fun_lunpacknum__case_5{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 fun_cunpacknum_: `%%%`(storagetype, lit_, lit_) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cunpacknum__case_0{c : lit_}: + `%%%`(I32_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cunpacknum__case_1{c : lit_}: + `%%%`(I64_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cunpacknum__case_2{c : lit_}: + `%%%`(F32_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cunpacknum__case_3{c : lit_}: + `%%%`(F64_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cunpacknum__case_4{c : lit_}: + `%%%`(V128_storagetype, c, c) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_cunpacknum__case_5{c : uN, var_0 : consttype?}: + `%%%`(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)))) + -- fun_cunpack: `%%`($storagetype_packtype(I8_packtype), var_0) + -- if (var_0 =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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 + rule fun_cunpacknum__case_6{c : uN, var_0 : consttype?}: + `%%%`(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)))) + -- fun_cunpack: `%%`($storagetype_packtype(I16_packtype), var_0) + -- if (var_0 =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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) + -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, 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) + -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, 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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#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)} + +;; ../../../../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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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#30)*{iter_0#30 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- lift(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#32)*{iter_0#32 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- lift(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#34)*{iter_0#34 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- lift(var_0)} + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + 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#36)*{iter_0#36 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- lift(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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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)))]) + -- 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 + 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)))]) + -- 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 + 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)))]) + -- 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 + 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)))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_testop_: `%%%%`(numtype, testop_, num_, u32) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_testop__case_0{i : uN, var_0 : u32}: + `%%%%`(I32_numtype, mk_testop__0_testop_(I32_Inn, EQZ_testop_Inn), mk_num__0_num_(I32_Inn, i), var_0) + -- fun_ieqz_: `%%%`($sizenn($numtype_addrtype(I32_Inn)), i, var_0) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_testop__case_1{i : uN, var_0 : u32}: + `%%%%`(I64_numtype, mk_testop__0_testop_(I64_Inn, EQZ_testop_Inn), mk_num__0_num_(I64_Inn, i), var_0) + -- fun_ieqz_: `%%%`($sizenn($numtype_addrtype(I64_Inn)), i, var_0) + +;; ../../../../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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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#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))} + + ;; ../../../../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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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))]) + -- 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 + 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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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#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)} + + ;; ../../../../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))]) + -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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))]) + -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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))]) + -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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))]) + -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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))]) + -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), 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))]) + -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), 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))]) + -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), 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))]) + -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) + -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) + +;; ../../../../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 +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}: + `%%%%`(`%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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_1{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_2{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_3{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_4{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_5{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_6{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_7{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_8{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_9{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_10{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_11{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_12{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_13{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_14{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_15{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_16{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#2833?{half#2833 <- `half?`}, sx)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_17{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#2834?{half#2834 <- `half?`}, sx)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_18{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#2835?{half#2835 <- `half?`}, sx)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_19{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#2836?{half#2836 <- `half?`}, sx)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_20{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#2837?{half#2837 <- `half?`}, sx)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_21{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#2838?{half#2838 <- `half?`}, sx)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_22{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#2839?{half#2839 <- `half?`}, sx)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_23{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#2840?{half#2840 <- `half?`}, sx)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_24{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#3245?{zero#3245 <- `zero?`})), zero#3246?{zero#3246 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_25{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#3247?{zero#3247 <- `zero?`})), zero#3248?{zero#3248 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_26{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#3249?{zero#3249 <- `zero?`})), zero#3250?{zero#3250 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_27{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#3251?{zero#3251 <- `zero?`})), zero#3252?{zero#3252 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_28{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#3253?{zero#3253 <- `zero?`})), zero#3254?{zero#3254 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_29{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#3255?{zero#3255 <- `zero?`})), zero#3256?{zero#3256 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_30{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#3257?{zero#3257 <- `zero?`})), zero#3258?{zero#3258 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_31{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#3259?{zero#3259 <- `zero?`})), zero#3260?{zero#3260 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_32{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#3261?{zero#3261 <- `zero?`})), zero#3262?{zero#3262 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_33{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#3263?{zero#3263 <- `zero?`})), zero#3264?{zero#3264 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_34{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#3265?{zero#3265 <- `zero?`})), zero#3266?{zero#3266 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_35{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#3267?{zero#3267 <- `zero?`})), zero#3268?{zero#3268 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_36{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#3269?{zero#3269 <- `zero?`})), zero#3270?{zero#3270 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_37{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#3271?{zero#3271 <- `zero?`})), zero#3272?{zero#3272 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_38{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#3273?{zero#3273 <- `zero?`})), zero#3274?{zero#3274 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_39{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#3275?{zero#3275 <- `zero?`})), zero#3276?{zero#3276 <- `zero?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_40{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_41{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_42{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_43{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_44{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), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_45{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), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_46{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), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_zeroop_case_47{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), ?()) + +;; ../../../../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}: + `%%%%`(`%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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_1{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_2{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_3{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_4{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_5{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_6{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_7{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_8{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_9{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_10{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_11{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_12{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_13{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_14{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_15{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_16{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#2841?{half#2841 <- `half?`}, sx)), half#2842?{half#2842 <- `half?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_17{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#2843?{half#2843 <- `half?`}, sx)), half#2844?{half#2844 <- `half?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_18{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#2845?{half#2845 <- `half?`}, sx)), half#2846?{half#2846 <- `half?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_19{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#2847?{half#2847 <- `half?`}, sx)), half#2848?{half#2848 <- `half?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_20{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#2849?{half#2849 <- `half?`}, sx)), half#2850?{half#2850 <- `half?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_21{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#2851?{half#2851 <- `half?`}, sx)), half#2852?{half#2852 <- `half?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_22{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#2853?{half#2853 <- `half?`}, sx)), half#2854?{half#2854 <- `half?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_23{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#2855?{half#2855 <- `half?`}, sx)), half#2856?{half#2856 <- `half?`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_24{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#3277?{zero#3277 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_25{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#3278?{zero#3278 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_26{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#3279?{zero#3279 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_27{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#3280?{zero#3280 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_28{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#3281?{zero#3281 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_29{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#3282?{zero#3282 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_30{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#3283?{zero#3283 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_31{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#3284?{zero#3284 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_32{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#3285?{zero#3285 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_33{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#3286?{zero#3286 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_34{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#3287?{zero#3287 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_35{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#3288?{zero#3288 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_36{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#3289?{zero#3289 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_37{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#3290?{zero#3290 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_38{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#3291?{zero#3291 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_39{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#3292?{zero#3292 <- `zero?`})), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_40{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_41{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_42{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_43{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)), ?()) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_44{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_45{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_46{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)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_halfop_case_47{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)) + +;; ../../../../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)) + -- 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, 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*`}|)]))) + -- wf_uN: `%%`(N, `%`_uN(0)) + -- 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, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#1))*{c_1#1 <- `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#3)))*{c#3 <- `c*`} + -- if (c_1#2*{c_1#2 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c#4*{c#4 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#3)))*{c_1#3 <- `c_1*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), 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#6)))*{c#6 <- `c*`} + -- if (c_1#5*{c_1#5 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c#7*{c#7 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#6)))*{c_1#6 <- `c_1*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#7))*{c_1#7 <- `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#9)))*{c#9 <- `c*`} + -- if (c_1#8*{c_1#8 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c#10*{c#10 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#9)))*{c_1#9 <- `c_1*`}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + def $ivunop_{M : nat, def $f_(N : N, iN : iN) : iN, v_1 : uN, `c*` : iN*, `c_1*` : lane_*}(`%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*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#10))*{c_1#10 <- `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#12)))*{c#12 <- `c*`} + -- if (c_1#11*{c_1#11 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c#13*{c#13 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#12)))*{c_1#12 <- `c_1*`}) + +;; ../../../../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, `c**` : lane_**, `c_1*` : lane_*}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#17*{c#17 <- `c*#3`})*{`c*#3` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), c#15))*{c#15 <- `c*#1`}*{`c*#1` <- `c**`} + -- 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#97))))*{iter_0#97 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#13)))))}*{c_1#13 <- `c_1*`} + -- if (c_1#14*{c_1#14 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1)) + -- if (c#16*{c#16 <- `c*#2`}*{`c*#2` <- `c**`} = $setproduct_(syntax lane_, 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#15)))))}*{c_1#15 <- `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, `c**` : lane_**, `c_1*` : lane_*}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#20*{c#20 <- `c*#6`})*{`c*#6` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), c#18))*{c#18 <- `c*#4`}*{`c*#4` <- `c**`} + -- 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#99))))*{iter_0#99 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#16)))))}*{c_1#16 <- `c_1*`} + -- if (c_1#17*{c_1#17 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1)) + -- if (c#19*{c#19 <- `c*#5`}*{`c*#5` <- `c**`} = $setproduct_(syntax lane_, 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#18)))))}*{c_1#18 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#23)*{c#23 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#19))*{c_1#19 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#1))*{c_2#1 <- `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#21)))*{c#21 <- `c*`} + -- if (c_1#20*{c_1#20 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#2*{c_2#2 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#22*{c#22 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#21)), !($proj_lane__2(c_2#3)))*{c_1#21 <- `c_1*`, c_2#3 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#26)*{c#26 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#22))*{c_1#22 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#4))*{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#24)))*{c#24 <- `c*`} + -- if (c_1#23*{c_1#23 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#5*{c_2#5 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#25*{c#25 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#24)), !($proj_lane__2(c_2#6)))*{c_1#24 <- `c_1*`, c_2#6 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#29)*{c#29 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#25))*{c_1#25 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#7))*{c_2#7 <- `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#27)))*{c#27 <- `c*`} + -- if (c_1#26*{c_1#26 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#8*{c_2#8 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#28*{c#28 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#27)), !($proj_lane__2(c_2#9)))*{c_1#27 <- `c_1*`, c_2#9 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#32)*{c#32 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#28))*{c_1#28 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#10))*{c_2#10 <- `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#30)))*{c#30 <- `c*`} + -- if (c_1#29*{c_1#29 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#11*{c_2#11 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#31*{c#31 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#30)), !($proj_lane__2(c_2#12)))*{c_1#30 <- `c_1*`, c_2#12 <- `c_2*`}) + +;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#35)*{c#35 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#31))*{c_1#31 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#13))*{c_2#13 <- `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#33)))*{c#33 <- `c*`} + -- if (c_1#32*{c_1#32 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#14*{c_2#14 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#34*{c#34 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#33)), !($proj_lane__2(c_2#15)))*{c_1#33 <- `c_1*`, c_2#15 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#38)*{c#38 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#34))*{c_1#34 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#16))*{c_2#16 <- `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#36)))*{c#36 <- `c*`} + -- if (c_1#35*{c_1#35 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#17*{c_2#17 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#37*{c#37 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#36)), !($proj_lane__2(c_2#18)))*{c_1#36 <- `c_1*`, c_2#18 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#41)*{c#41 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#37))*{c_1#37 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#19))*{c_2#19 <- `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#39)))*{c#39 <- `c*`} + -- if (c_1#38*{c_1#38 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#20*{c_2#20 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#40*{c#40 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#39)), !($proj_lane__2(c_2#21)))*{c_1#39 <- `c_1*`, c_2#21 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#44)*{c#44 <- `c*`})] + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#40))*{c_1#40 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#22))*{c_2#22 <- `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#42)))*{c#42 <- `c*`} + -- if (c_1#41*{c_1#41 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#23*{c_2#23 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#43*{c#43 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#42)), !($proj_lane__2(c_2#24)))*{c_1#42 <- `c_1*`, c_2#24 <- `c_2*`}) + +;; ../../../../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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I32_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#47*{c#47 <- `c*#9`})*{`c*#9` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), c#45))*{c#45 <- `c*#7`}*{`c*#7` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#101)))*{iter_0#101 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#43)), !($proj_lane__2(c_2#25)))}*{c_1#43 <- `c_1*`, c_2#25 <- `c_2*`} + -- if (c_1#44*{c_1#44 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#26*{c_2#26 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#46*{c#46 <- `c*#8`}*{`c*#8` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#102)*{iter_0#102 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#45)), !($proj_lane__2(c_2#27)))}*{c_1#45 <- `c_1*`, c_2#27 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I64_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#50*{c#50 <- `c*#12`})*{`c*#12` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), c#48))*{c#48 <- `c*#10`}*{`c*#10` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#103)))*{iter_0#103 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#46)), !($proj_lane__2(c_2#28)))}*{c_1#46 <- `c_1*`, c_2#28 <- `c_2*`} + -- if (c_1#47*{c_1#47 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#29*{c_2#29 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#49*{c#49 <- `c*#11`}*{`c*#11` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#104)*{iter_0#104 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#48)), !($proj_lane__2(c_2#30)))}*{c_1#48 <- `c_1*`, c_2#30 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I8_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#53*{c#53 <- `c*#15`})*{`c*#15` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), c#51))*{c#51 <- `c*#13`}*{`c*#13` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#105)))*{iter_0#105 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#49)), !($proj_lane__2(c_2#31)))}*{c_1#49 <- `c_1*`, c_2#31 <- `c_2*`} + -- if (c_1#50*{c_1#50 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#32*{c_2#32 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#52*{c#52 <- `c*#14`}*{`c*#14` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#106)*{iter_0#106 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#51)), !($proj_lane__2(c_2#33)))}*{c_1#51 <- `c_1*`, c_2#33 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(I16_lanetype, `%`_dim(M)), def $f_, sx, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#56*{c#56 <- `c*#18`})*{`c*#18` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), c#54))*{c#54 <- `c*#16`}*{`c*#16` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#107)))*{iter_0#107 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#52)), !($proj_lane__2(c_2#34)))}*{c_1#52 <- `c_1*`, c_2#34 <- `c_2*`} + -- if (c_1#53*{c_1#53 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#35*{c_2#35 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#55*{c#55 <- `c*#17`}*{`c*#17` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#108)*{iter_0#108 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#54)), !($proj_lane__2(c_2#36)))}*{c_1#54 <- `c_1*`, c_2#36 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(F32_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), c#59*{c#59 <- `c*#21`})*{`c*#21` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), c#57))*{c#57 <- `c*#19`}*{`c*#19` <- `c**`} + -- 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#109))))*{iter_0#109 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#55)))), !($proj_num__1(!($proj_lane__0(c_2#37)))))}*{c_1#55 <- `c_1*`, c_2#37 <- `c_2*`} + -- if (c_1#56*{c_1#56 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#38*{c_2#38 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2)) + -- if (c#58*{c#58 <- `c*#20`}*{`c*#20` <- `c**`} = $setproduct_(syntax lane_, 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#57)))), !($proj_num__1(!($proj_lane__0(c_2#39)))))}*{c_1#57 <- `c_1*`, c_2#39 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*}(`%X%`_shape(F64_lanetype, `%`_dim(M)), def $f_, v_1, v_2) = $inv_lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), c#62*{c#62 <- `c*#24`})*{`c*#24` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), c#60))*{c#60 <- `c*#22`}*{`c*#22` <- `c**`} + -- 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#111))))*{iter_0#111 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#58)))), !($proj_num__1(!($proj_lane__0(c_2#40)))))}*{c_1#58 <- `c_1*`, c_2#40 <- `c_2*`} + -- if (c_1#59*{c_1#59 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#41*{c_2#41 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2)) + -- if (c#61*{c#61 <- `c*#23`}*{`c*#23` <- `c**`} = $setproduct_(syntax lane_, 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#60)))), !($proj_num__1(!($proj_lane__0(c_2#42)))))}*{c_1#60 <- `c_1*`, c_2#42 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#65*{c#65 <- `c*#27`})*{`c*#27` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), c#63))*{c#63 <- `c*#25`}*{`c*#25` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I32_Jnn), mk_lane__2_lane_(I32_Jnn, iter_0#113)))*{iter_0#113 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#61)), !($proj_lane__2(c_2#43)), !($proj_lane__2(c_3#1)))}*{c_1#61 <- `c_1*`, c_2#43 <- `c_2*`, c_3#1 <- `c_3*`} + -- if (c_1#62*{c_1#62 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#44*{c_2#44 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c_3#2*{c_3#2 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_3)) + -- if (c#64*{c#64 <- `c*#26`}*{`c*#26` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I32_Jnn, iter_0#114)*{iter_0#114 <- $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#63)), !($proj_lane__2(c_2#45)), !($proj_lane__2(c_3#3)))}*{c_1#63 <- `c_1*`, c_2#45 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#68*{c#68 <- `c*#30`})*{`c*#30` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), c#66))*{c#66 <- `c*#28`}*{`c*#28` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I64_Jnn), mk_lane__2_lane_(I64_Jnn, iter_0#115)))*{iter_0#115 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#64)), !($proj_lane__2(c_2#46)), !($proj_lane__2(c_3#4)))}*{c_1#64 <- `c_1*`, c_2#46 <- `c_2*`, c_3#4 <- `c_3*`} + -- if (c_1#65*{c_1#65 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#47*{c_2#47 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c_3#5*{c_3#5 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_3)) + -- if (c#67*{c#67 <- `c*#29`}*{`c*#29` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I64_Jnn, iter_0#116)*{iter_0#116 <- $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#66)), !($proj_lane__2(c_2#48)), !($proj_lane__2(c_3#6)))}*{c_1#66 <- `c_1*`, c_2#48 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#71*{c#71 <- `c*#33`})*{`c*#33` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), c#69))*{c#69 <- `c*#31`}*{`c*#31` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I8_Jnn), mk_lane__2_lane_(I8_Jnn, iter_0#117)))*{iter_0#117 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#67)), !($proj_lane__2(c_2#49)), !($proj_lane__2(c_3#7)))}*{c_1#67 <- `c_1*`, c_2#49 <- `c_2*`, c_3#7 <- `c_3*`} + -- if (c_1#68*{c_1#68 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#50*{c_2#50 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c_3#8*{c_3#8 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_3)) + -- if (c#70*{c#70 <- `c*#32`}*{`c*#32` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I8_Jnn, iter_0#118)*{iter_0#118 <- $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#69)), !($proj_lane__2(c_2#51)), !($proj_lane__2(c_3#9)))}*{c_1#69 <- `c_1*`, c_2#51 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#74*{c#74 <- `c*#36`})*{`c*#36` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), c#72))*{c#72 <- `c*#34`}*{`c*#34` <- `c**`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (wf_lane_: `%%`($lanetype_Jnn(I16_Jnn), mk_lane__2_lane_(I16_Jnn, iter_0#119)))*{iter_0#119 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#70)), !($proj_lane__2(c_2#52)), !($proj_lane__2(c_3#10)))}*{c_1#70 <- `c_1*`, c_2#52 <- `c_2*`, c_3#10 <- `c_3*`} + -- if (c_1#71*{c_1#71 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#53*{c_2#53 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c_3#11*{c_3#11 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_3)) + -- if (c#73*{c#73 <- `c*#35`}*{`c*#35` <- `c**`} = $setproduct_(syntax lane_, mk_lane__2_lane_(I16_Jnn, iter_0#120)*{iter_0#120 <- $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#72)), !($proj_lane__2(c_2#54)), !($proj_lane__2(c_3#12)))}*{c_1#72 <- `c_1*`, c_2#54 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#77*{c#77 <- `c*#39`})*{`c*#39` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), c#75))*{c#75 <- `c*#37`}*{`c*#37` <- `c**`} + -- 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#121))))*{iter_0#121 <- $f_($sizenn($numtype_Fnn(F32_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#73)))), !($proj_num__1(!($proj_lane__0(c_2#55)))), !($proj_num__1(!($proj_lane__0(c_3#13)))))}*{c_1#73 <- `c_1*`, c_2#55 <- `c_2*`, c_3#13 <- `c_3*`} + -- if (c_1#74*{c_1#74 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#56*{c_2#56 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2)) + -- if (c_3#14*{c_3#14 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_3)) + -- if (c#76*{c#76 <- `c*#38`}*{`c*#38` <- `c**`} = $setproduct_(syntax lane_, 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#75)))), !($proj_num__1(!($proj_lane__0(c_2#57)))), !($proj_num__1(!($proj_lane__0(c_3#15)))))}*{c_1#75 <- `c_1*`, c_2#57 <- `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, `c**` : lane_**, `c_1*` : lane_*, `c_2*` : lane_*, `c_3*` : lane_*}(`%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#80*{c#80 <- `c*#42`})*{`c*#42` <- `c**`} + -- (wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), c#78))*{c#78 <- `c*#40`}*{`c*#40` <- `c**`} + -- 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#123))))*{iter_0#123 <- $f_($sizenn($numtype_Fnn(F64_Fnn)), !($proj_num__1(!($proj_lane__0(c_1#76)))), !($proj_num__1(!($proj_lane__0(c_2#58)))), !($proj_num__1(!($proj_lane__0(c_3#16)))))}*{c_1#76 <- `c_1*`, c_2#58 <- `c_2*`, c_3#16 <- `c_3*`} + -- if (c_1#77*{c_1#77 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#59*{c_2#59 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2)) + -- if (c_3#17*{c_3#17 <- `c_3*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_3)) + -- if (c#79*{c#79 <- `c*#41`}*{`c*#41` <- `c**`} = $setproduct_(syntax lane_, 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#78)))), !($proj_num__1(!($proj_lane__0(c_2#60)))), !($proj_num__1(!($proj_lane__0(c_3#18)))))}*{c_1#78 <- `c_1*`, c_2#60 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#83)*{c#83 <- `c*`}) + -- 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#81)))*{c#81 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#79)), !($proj_lane__2(c_2#61)))).0)))*{c_1#79 <- `c_1*`, c_2#61 <- `c_2*`} + -- if (c_1#80*{c_1#80 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#62*{c_2#62 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#82*{c#82 <- `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#81)), !($proj_lane__2(c_2#63)))).0))*{c_1#81 <- `c_1*`, c_2#63 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#86)*{c#86 <- `c*`}) + -- 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#84)))*{c#84 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#82)), !($proj_lane__2(c_2#64)))).0)))*{c_1#82 <- `c_1*`, c_2#64 <- `c_2*`} + -- if (c_1#83*{c_1#83 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#65*{c_2#65 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#85*{c#85 <- `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#84)), !($proj_lane__2(c_2#66)))).0))*{c_1#84 <- `c_1*`, c_2#66 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#89)*{c#89 <- `c*`}) + -- 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#87)))*{c#87 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#85)), !($proj_lane__2(c_2#67)))).0)))*{c_1#85 <- `c_1*`, c_2#67 <- `c_2*`} + -- if (c_1#86*{c_1#86 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#68*{c_2#68 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#88*{c#88 <- `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#87)), !($proj_lane__2(c_2#69)))).0))*{c_1#87 <- `c_1*`, c_2#69 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#92)*{c#92 <- `c*`}) + -- 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#90)))*{c#90 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#88)), !($proj_lane__2(c_2#70)))).0)))*{c_1#88 <- `c_1*`, c_2#70 <- `c_2*`} + -- if (c_1#89*{c_1#89 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#71*{c_2#71 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#91*{c#91 <- `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#90)), !($proj_lane__2(c_2#72)))).0))*{c_1#90 <- `c_1*`, c_2#72 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#95)*{c#95 <- `c*`}) + -- 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#93)))*{c#93 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#91)), !($proj_lane__2(c_2#73)))).0)))*{c_1#91 <- `c_1*`, c_2#73 <- `c_2*`} + -- if (c_1#92*{c_1#92 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#74*{c_2#74 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#94*{c#94 <- `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#93)), !($proj_lane__2(c_2#75)))).0))*{c_1#93 <- `c_1*`, c_2#75 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#98)*{c#98 <- `c*`}) + -- 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#96)))*{c#96 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#94)), !($proj_lane__2(c_2#76)))).0)))*{c_1#94 <- `c_1*`, c_2#76 <- `c_2*`} + -- if (c_1#95*{c_1#95 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#77*{c_2#77 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#97*{c#97 <- `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#96)), !($proj_lane__2(c_2#78)))).0))*{c_1#96 <- `c_1*`, c_2#78 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#101)*{c#101 <- `c*`}) + -- 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#99)))*{c#99 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#97)), !($proj_lane__2(c_2#79)))).0)))*{c_1#97 <- `c_1*`, c_2#79 <- `c_2*`} + -- if (c_1#98*{c_1#98 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#80*{c_2#80 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#100*{c#100 <- `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#99)), !($proj_lane__2(c_2#81)))).0))*{c_1#99 <- `c_1*`, c_2#81 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#104)*{c#104 <- `c*`}) + -- 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#102)))*{c#102 <- `c*`} + -- (wf_uN: `%%`(1, `%`_uN($proj_uN_0($f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#100)), !($proj_lane__2(c_2#82)))).0)))*{c_1#100 <- `c_1*`, c_2#82 <- `c_2*`} + -- if (c_1#101*{c_1#101 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#83*{c_2#83 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#103*{c#103 <- `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#102)), !($proj_lane__2(c_2#84)))).0))*{c_1#102 <- `c_1*`, c_2#84 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#107).0)))*{c#107 <- `c*`}) + -- 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#105).0)))))*{c#105 <- `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#103)))), !($proj_num__1(!($proj_lane__0(c_2#85)))))).0)))*{c_1#103 <- `c_1*`, c_2#85 <- `c_2*`} + -- if (c_1#104*{c_1#104 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#86*{c_2#86 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F32_Fnn), `%`_dim(M)), v_2)) + -- if (c#106*{c#106 <- `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#105)))), !($proj_num__1(!($proj_lane__0(c_2#87)))))).0))*{c_1#105 <- `c_1*`, c_2#87 <- `c_2*`}) + -- if ($isize(Inn) = $fsize(F32_Fnn)) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#110).0)))*{c#110 <- `c*`}) + -- 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#108).0)))))*{c#108 <- `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#106)))), !($proj_num__1(!($proj_lane__0(c_2#88)))))).0)))*{c_1#106 <- `c_1*`, c_2#88 <- `c_2*`} + -- if (c_1#107*{c_1#107 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_1)) + -- if (c_2#89*{c_2#89 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Fnn(F64_Fnn), `%`_dim(M)), v_2)) + -- if (c#109*{c#109 <- `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#108)))), !($proj_num__1(!($proj_lane__0(c_2#90)))))).0))*{c_1#108 <- `c_1*`, c_2#90 <- `c_2*`}) + -- if ($isize(Inn) = $fsize(F64_Fnn)) + +;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#113)*{c#113 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#109))*{c_1#109 <- `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#111)))*{c#111 <- `c*`} + -- if (c_1#110*{c_1#110 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c#112*{c#112 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#111)), i)*{c_1#111 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#116)*{c#116 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#112))*{c_1#112 <- `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#114)))*{c#114 <- `c*`} + -- if (c_1#113*{c_1#113 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c#115*{c#115 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#114)), i)*{c_1#114 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#119)*{c#119 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#115))*{c_1#115 <- `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#117)))*{c#117 <- `c*`} + -- if (c_1#116*{c_1#116 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c#118*{c#118 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#117)), i)*{c_1#117 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#122)*{c#122 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#118))*{c_1#118 <- `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#120)))*{c#120 <- `c*`} + -- if (c_1#119*{c_1#119 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c#121*{c#121 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#120)), i)*{c_1#120 <- `c_1*`}) + +;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#125)*{c#125 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#121))*{c_1#121 <- `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#123)))*{c#123 <- `c*`} + -- if (c_1#122*{c_1#122 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c#124*{c#124 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#123)), i)*{c_1#123 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#128)*{c#128 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#124))*{c_1#124 <- `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#126)))*{c#126 <- `c*`} + -- if (c_1#125*{c_1#125 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c#127*{c#127 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#126)), i)*{c_1#126 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#131)*{c#131 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#127))*{c_1#127 <- `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#129)))*{c#129 <- `c*`} + -- if (c_1#128*{c_1#128 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c#130*{c#130 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#129)), i)*{c_1#129 <- `c_1*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*}(`%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#134)*{c#134 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#130))*{c_1#130 <- `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#132)))*{c#132 <- `c*`} + -- if (c_1#131*{c_1#131 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c#133*{c#133 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#132)), i)*{c_1#132 <- `c_1*`}) + +;; ../../../../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, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- wf_uN: `%%`(32, c) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- (if ($proj_lane__2(c_1#133) =/= ?()))*{c_1#133 <- `c_1*`} + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#133)), `%`_iN(0))).0)))*{c_1#133 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + -- if (c_1#134*{c_1#134 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- (if ($proj_lane__2(c_1#135) =/= ?()))*{c_1#135 <- `c_1*`} + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#135)), `%`_iN(0))).0)*{c_1#135 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_1{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- wf_uN: `%%`(32, c) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- (if ($proj_lane__2(c_1#136) =/= ?()))*{c_1#136 <- `c_1*`} + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#136)), `%`_iN(0))).0)))*{c_1#136 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + -- if (c_1#137*{c_1#137 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- (if ($proj_lane__2(c_1#138) =/= ?()))*{c_1#138 <- `c_1*`} + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#138)), `%`_iN(0))).0)*{c_1#138 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_2{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- wf_uN: `%%`(32, c) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- (if ($proj_lane__2(c_1#139) =/= ?()))*{c_1#139 <- `c_1*`} + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#139)), `%`_iN(0))).0)))*{c_1#139 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + -- if (c_1#140*{c_1#140 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- (if ($proj_lane__2(c_1#141) =/= ?()))*{c_1#141 <- `c_1*`} + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#141)), `%`_iN(0))).0)*{c_1#141 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivbitmaskop__case_3{M : nat, v_1 : uN, c : uN, `c_1*` : lane_*}: + `%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), v_1, $irev_(32, c)) + -- wf_uN: `%%`(32, c) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- (if ($proj_lane__2(c_1#142) =/= ?()))*{c_1#142 <- `c_1*`} + -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#142)), `%`_iN(0))).0)))*{c_1#142 <- `c_1*`} + -- wf_bit: `%`(`%`_bit(0)) + -- if (c_1#143*{c_1#143 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- (if ($proj_lane__2(c_1#144) =/= ?()))*{c_1#144 <- `c_1*`} + -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#144)), `%`_iN(0))).0)*{c_1#144 <- `c_1*`} ++ `%`_bit(0)^(((32 : nat <:> int) - (M : nat <:> int)) : int <:> nat){}) + +;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#137)*{c#137 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#145))*{c_1#145 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#91))*{c_2#91 <- `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#135)))*{c#135 <- `c*`} + -- if (c_1#146*{c_1#146 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#92*{c_2#92 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- if (c#136*{c#136 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I32_Jnn)), !($proj_lane__2(c_1#147))*{c_1#147 <- `c_1*`}, !($proj_lane__2(c_2#93)))*{c_2#93 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#140)*{c#140 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#148))*{c_1#148 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#94))*{c_2#94 <- `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#138)))*{c#138 <- `c*`} + -- if (c_1#149*{c_1#149 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#95*{c_2#95 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- if (c#139*{c#139 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I64_Jnn)), !($proj_lane__2(c_1#150))*{c_1#150 <- `c_1*`}, !($proj_lane__2(c_2#96)))*{c_2#96 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#143)*{c#143 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#151))*{c_1#151 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#97))*{c_2#97 <- `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#141)))*{c#141 <- `c*`} + -- if (c_1#152*{c_1#152 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#98*{c_2#98 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- if (c#142*{c#142 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I8_Jnn)), !($proj_lane__2(c_1#153))*{c_1#153 <- `c_1*`}, !($proj_lane__2(c_2#99)))*{c_2#99 <- `c_2*`}) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*}(`%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#146)*{c#146 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#154))*{c_1#154 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#100))*{c_2#100 <- `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#144)))*{c#144 <- `c*`} + -- if (c_1#155*{c_1#155 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#101*{c_2#101 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- if (c#145*{c#145 <- `c*`} = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#156))*{c_1#156 <- `c_1*`}, !($proj_lane__2(c_2#102)))*{c_2#102 <- `c_2*`}) + +;; ../../../../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, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M)), i#128389*{i#128389 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), c#149*{c#149 <- `c*`})) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c#147))*{c#147 <- `c*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_1#157))*{c_1#157 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))), c_2#103))*{c_2#103 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- if (c_1#158*{c_1#158 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#104*{c_2#104 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M)), v_2)) + -- (if ($proj_uN_0(i#128396).0 < |c_1#159*{c_1#159 <- `c_1*`} ++ c_2#105*{c_2#105 <- `c_2*`}|))*{i#128396 <- `i*`} + -- if (c#148*{c#148 <- `c*`} = c_1#159*{c_1#159 <- `c_1*`} ++ c_2#105*{c_2#105 <- `c_2*`}[$proj_uN_0(i#128396).0]*{i#128396 <- `i*`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_1{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M)), i#128399*{i#128399 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), c#152*{c#152 <- `c*`})) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c#150))*{c#150 <- `c*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_1#160))*{c_1#160 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))), c_2#106))*{c_2#106 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- if (c_1#161*{c_1#161 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#107*{c_2#107 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M)), v_2)) + -- (if ($proj_uN_0(i#128406).0 < |c_1#162*{c_1#162 <- `c_1*`} ++ c_2#108*{c_2#108 <- `c_2*`}|))*{i#128406 <- `i*`} + -- if (c#151*{c#151 <- `c*`} = c_1#162*{c_1#162 <- `c_1*`} ++ c_2#108*{c_2#108 <- `c_2*`}[$proj_uN_0(i#128406).0]*{i#128406 <- `i*`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_2{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i#128409*{i#128409 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), c#155*{c#155 <- `c*`})) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c#153))*{c#153 <- `c*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_1#163))*{c_1#163 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))), c_2#109))*{c_2#109 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- if (c_1#164*{c_1#164 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#110*{c_2#110 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M)), v_2)) + -- (if ($proj_uN_0(i#128416).0 < |c_1#165*{c_1#165 <- `c_1*`} ++ c_2#111*{c_2#111 <- `c_2*`}|))*{i#128416 <- `i*`} + -- if (c#154*{c#154 <- `c*`} = c_1#165*{c_1#165 <- `c_1*`} ++ c_2#111*{c_2#111 <- `c_2*`}[$proj_uN_0(i#128416).0]*{i#128416 <- `i*`}) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_ivshufflop__case_3{M : nat, `i*` : laneidx*, v_1 : uN, v_2 : uN, `c*` : lane_*, `c_1*` : lane_*, `c_2*` : lane_*}: + `%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M)), i#128419*{i#128419 <- `i*`}, v_1, v_2, $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), c#158*{c#158 <- `c*`})) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c#156))*{c#156 <- `c*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_1#166))*{c_1#166 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))), c_2#112))*{c_2#112 <- `c_2*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- if (c_1#167*{c_1#167 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_1)) + -- if (c_2#113*{c_2#113 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M)), v_2)) + -- (if ($proj_uN_0(i#128426).0 < |c_1#168*{c_1#168 <- `c_1*`} ++ c_2#114*{c_2#114 <- `c_2*`}|))*{i#128426 <- `i*`} + -- if (c#157*{c#157 <- `c*`} = c_1#168*{c_1#168 <- `c_1*`} ++ c_2#114*{c_2#114 <- `c_2*`}[$proj_uN_0(i#128426).0]*{i#128426 <- `i*`}) + +;; ../../../../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}: + `%%%%`(`%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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_1{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_2{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_3{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_4{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_5{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_6{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_7{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_8{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_9{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_10{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_11{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_12{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_13{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_14{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_15{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_16{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_17{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_18{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_19{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_20{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_21{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_22{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_23{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_24{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vunop__case_25{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))) + +;; ../../../../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}: + `%%%%%`(`%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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_1{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_2{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_3{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_4{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_5{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_6{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_7{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_8{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_9{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_10{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_11{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_12{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_13{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_14{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_15{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_16{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_17{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_18{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_19{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_20{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_21{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_22{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_23{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_24{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_25{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_26{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_27{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_28{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_29{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_30{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_31{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_32{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_33{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_34{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_35{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_36{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_37{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_38{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_39{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_40{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_41{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_42{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_43{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_44{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_45{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_46{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_47{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_48{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_49{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_50{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_51{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_52{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_53{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_54{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_55{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_56{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_57{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_58{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vbinop__case_59{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))) + +;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + + ;; ../../../../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}: + `%%%%%%`(`%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))) + +;; ../../../../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}: + `%%%%%`(`%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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_1{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_2{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_3{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_4{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_5{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_6{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_7{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_8{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_9{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_10{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_11{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_12{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_13{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_14{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_15{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_16{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_17{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_18{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_19{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_20{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_21{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_22{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_23{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_24{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_25{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_26{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_27{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_28{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_29{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_30{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_31{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_32{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_33{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_34{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vrelop__case_35{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))) + +;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + + ;; ../../../../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, c : 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)]) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) + -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2857?{half#2857 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2858?{half#2858 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2859?{half#2859 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2860?{half#2860 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2861?{half#2861 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2862?{half#2862 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2863?{half#2863 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + + ;; ../../../../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, c : fN}: + `%%%%%`(`%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#2864?{half#2864 <- `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))]) + -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3293?{zero#3293 <- `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#161))?{c#161 <- `c?`})) + -- (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#159))))?{c#159 <- `c?`} + -- if (c#160?{c#160 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3294?{zero#3294 <- `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#164))?{c#164 <- `c?`})) + -- (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#162))))?{c#162 <- `c?`} + -- if (c#163?{c#163 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3295?{zero#3295 <- `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#167))?{c#167 <- `c?`})) + -- (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#165))))?{c#165 <- `c?`} + -- if (c#166?{c#166 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3296?{zero#3296 <- `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#170))?{c#170 <- `c?`})) + -- (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#168))))?{c#168 <- `c?`} + -- if (c#169?{c#169 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3297?{zero#3297 <- `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#173))?{c#173 <- `c?`})) + -- (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#171))))?{c#171 <- `c?`} + -- if (c#172?{c#172 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3298?{zero#3298 <- `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#176))?{c#176 <- `c?`})) + -- (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#174))))?{c#174 <- `c?`} + -- if (c#175?{c#175 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3299?{zero#3299 <- `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#179))?{c#179 <- `c?`})) + -- (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#177))))?{c#177 <- `c?`} + -- if (c#178?{c#178 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3300?{zero#3300 <- `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#182))?{c#182 <- `c?`})) + -- (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#180))))?{c#180 <- `c?`} + -- if (c#181?{c#181 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3301?{zero#3301 <- `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#185))?{c#185 <- `c?`})) + -- (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#183))))?{c#183 <- `c?`} + -- if (c#184?{c#184 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3302?{zero#3302 <- `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#188))?{c#188 <- `c?`})) + -- (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#186))))?{c#186 <- `c?`} + -- if (c#187?{c#187 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3303?{zero#3303 <- `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#191))?{c#191 <- `c?`})) + -- (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#189))))?{c#189 <- `c?`} + -- if (c#190?{c#190 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3304?{zero#3304 <- `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#194))?{c#194 <- `c?`})) + -- (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#192))))?{c#192 <- `c?`} + -- if (c#193?{c#193 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3305?{zero#3305 <- `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#197))?{c#197 <- `c?`})) + -- (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#195))))?{c#195 <- `c?`} + -- if (c#196?{c#196 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3306?{zero#3306 <- `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#200))?{c#200 <- `c?`})) + -- (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#198))))?{c#198 <- `c?`} + -- if (c#199?{c#199 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3307?{zero#3307 <- `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#203))?{c#203 <- `c?`})) + -- (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#201))))?{c#201 <- `c?`} + -- if (c#202?{c#202 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3308?{zero#3308 <- `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#206))?{c#206 <- `c?`})) + -- (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#204))))?{c#204 <- `c?`} + -- if (c#205?{c#205 <- `c?`} = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3309?{zero#3309 <- `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#209))?{c#209 <- `c?`})) + -- (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#207))))?{c#207 <- `c?`} + -- if (c#208?{c#208 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3310?{zero#3310 <- `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#212))?{c#212 <- `c?`})) + -- (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#210))))?{c#210 <- `c?`} + -- if (c#211?{c#211 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3311?{zero#3311 <- `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#215))?{c#215 <- `c?`})) + -- (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#213))))?{c#213 <- `c?`} + -- if (c#214?{c#214 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3312?{zero#3312 <- `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#218))?{c#218 <- `c?`})) + -- (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#216))))?{c#216 <- `c?`} + -- if (c#217?{c#217 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3313?{zero#3313 <- `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#221))?{c#221 <- `c?`})) + -- (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#219))))?{c#219 <- `c?`} + -- if (c#220?{c#220 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3314?{zero#3314 <- `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#224))?{c#224 <- `c?`})) + -- (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#222))))?{c#222 <- `c?`} + -- if (c#223?{c#223 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3315?{zero#3315 <- `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#227))?{c#227 <- `c?`})) + -- (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#225))))?{c#225 <- `c?`} + -- if (c#226?{c#226 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3316?{zero#3316 <- `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#230))?{c#230 <- `c?`})) + -- (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#228))))?{c#228 <- `c?`} + -- if (c#229?{c#229 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3317?{zero#3317 <- `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#233))?{c#233 <- `c?`})) + -- (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#231))))?{c#231 <- `c?`} + -- if (c#232?{c#232 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3318?{zero#3318 <- `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#236))?{c#236 <- `c?`})) + -- (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#234))))?{c#234 <- `c?`} + -- if (c#235?{c#235 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3319?{zero#3319 <- `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#239))?{c#239 <- `c?`})) + -- (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#237))))?{c#237 <- `c?`} + -- if (c#238?{c#238 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3320?{zero#3320 <- `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#242))?{c#242 <- `c?`})) + -- (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#240))))?{c#240 <- `c?`} + -- if (c#241?{c#241 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3321?{zero#3321 <- `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#245))?{c#245 <- `c?`})) + -- (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#243))))?{c#243 <- `c?`} + -- if (c#244?{c#244 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3322?{zero#3322 <- `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#248))?{c#248 <- `c?`})) + -- (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#246))))?{c#246 <- `c?`} + -- if (c#247?{c#247 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3323?{zero#3323 <- `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#251))?{c#251 <- `c?`})) + -- (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#249))))?{c#249 <- `c?`} + -- if (c#250?{c#250 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../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, `c?` : iN?}: + `%%%%%`(`%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#3324?{zero#3324 <- `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#254))?{c#254 <- `c?`})) + -- (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#252))))?{c#252 <- `c?`} + -- if (c#253?{c#253 <- `c?`} = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), sx, c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_56{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#257))*{c#257 <- `c*`}) + -- (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#255))))*{c#255 <- `c*`} + -- if (c#256*{c#256 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_57{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#260))*{c#260 <- `c*`}) + -- (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#258))))*{c#258 <- `c*`} + -- if (c#259*{c#259 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_58{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#263))*{c#263 <- `c*`}) + -- (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#261))))*{c#261 <- `c*`} + -- if (c#262*{c#262 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_59{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#266))*{c#266 <- `c*`}) + -- (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#264))))*{c#264 <- `c*`} + -- if (c#265*{c#265 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_60{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#269))*{c#269 <- `c*`}) + -- (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#267))))*{c#267 <- `c*`} + -- if (c#268*{c#268 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_61{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#272))*{c#272 <- `c*`}) + -- (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#270))))*{c#270 <- `c*`} + -- if (c#271*{c#271 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_62{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#275))*{c#275 <- `c*`}) + -- (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#273))))*{c#273 <- `c*`} + -- if (c#274*{c#274 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_63{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#278))*{c#278 <- `c*`}) + -- (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#276))))*{c#276 <- `c*`} + -- if (c#277*{c#277 <- `c*`} = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_64{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#281))*{c#281 <- `c*`}) + -- (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#279))))*{c#279 <- `c*`} + -- if (c#280*{c#280 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_65{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#284))*{c#284 <- `c*`}) + -- (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#282))))*{c#282 <- `c*`} + -- if (c#283*{c#283 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_66{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#287))*{c#287 <- `c*`}) + -- (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#285))))*{c#285 <- `c*`} + -- if (c#286*{c#286 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_67{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#290))*{c#290 <- `c*`}) + -- (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#288))))*{c#288 <- `c*`} + -- if (c#289*{c#289 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_68{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#293))*{c#293 <- `c*`}) + -- (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#291))))*{c#291 <- `c*`} + -- if (c#292*{c#292 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_69{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#296))*{c#296 <- `c*`}) + -- (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#294))))*{c#294 <- `c*`} + -- if (c#295*{c#295 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_70{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#299))*{c#299 <- `c*`}) + -- (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#297))))*{c#297 <- `c*`} + -- if (c#298*{c#298 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_lcvtop___case_71{M_1 : nat, M_2 : nat, c_1 : fN, `c*` : 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#302))*{c#302 <- `c*`}) + -- (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#300))))*{c#300 <- `c*`} + -- if (c#301*{c#301 <- `c*`} = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + +;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1, v) + -- if (|`var_2*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M))), c_1#169))*{c_1#169 <- `c_1*`} + -- (wf_lane_: `%%`(Lnn_2, c#303))*{c#303 <- `c*#43`}*{`c*#43` <- `c**`} + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M))) + -- if ((var_0 = ?()) /\ (var_1 = ?())) + -- if (c_1#170*{c_1#170 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1)) + -- if (c#304*{c#304 <- `c*#44`}*{`c*#44` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`})) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}| > 0) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}) + + ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**, `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_1*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `c_1*`} + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#172))*{c_1#172 <- `c_1*`} + -- (wf_lane_: `%%`(Lnn_2, c#306))*{c#306 <- `c*#46`}*{`c*#46` <- `c**`} + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- if (var_0 = ?(half)) + -- if (c_1#173*{c_1#173 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2]) + -- if (c#307*{c#307 <- `c*#47`}*{`c*#47` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`})) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}| > 0) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}) + + ;; ../../../../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, `c_1*` : lane_*, `c**` : lane_**, var_2 : lane_, `var_1*` : lane_**, var_0 : zero?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- fun_zero: `%%`(Lnn_2, var_2) + -- if (|`var_1*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `c_1*`} + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#175))*{c_1#175 <- `c_1*`} + -- (wf_lane_: `%%`(Lnn_2, c#309))*{c#309 <- `c*#49`}*{`c*#49` <- `c**`} + -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) + -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) + -- if (var_0 = ?(ZERO_zero)) + -- if (c_1#176*{c_1#176 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)) + -- if (c#310*{c#310 <- `c*#50`}*{`c*#50` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [var_2]^M_1{})) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}| > 0) + -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}) + +;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_1{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_2{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_3{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_4{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_5{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_6{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))) + + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec + rule fun_vshiftop__case_7{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))) + +;; ../../../../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) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + + ;; ../../../../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) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + + ;; ../../../../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) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + + ;; ../../../../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) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + +;; ../../../../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}: + `%%%%%`(`%`_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 + rule fun_vswizzlop__case_1{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 +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#129110*{i#129110 <- `i*`}, v_1, v_2, var_0) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) + -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + +;; ../../../../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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#178))*{c_1#178 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#115))*{c_2#115 <- `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#1)))*{c'_1#1 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#1)))*{c'_2#1 <- `c'_2*`} + -- if (c_1#179*{c_1#179 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#116*{c_2#116 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#180) =/= ?()))*{c_1#180 <- `c_1*`} + -- if (c'_1#2*{c'_1#2 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#117) =/= ?()))*{c_2#117 <- `c_2*`} + -- if (c'_2#2*{c'_2#2 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#117)))*{c_2#117 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#3)*{c'_1#3 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#181))*{c_1#181 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#118))*{c_2#118 <- `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#4)))*{c'_1#4 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#4)))*{c'_2#4 <- `c'_2*`} + -- if (c_1#182*{c_1#182 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#119*{c_2#119 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#183) =/= ?()))*{c_1#183 <- `c_1*`} + -- if (c'_1#5*{c'_1#5 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#183)))*{c_1#183 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#120) =/= ?()))*{c_2#120 <- `c_2*`} + -- if (c'_2#5*{c'_2#5 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#120)))*{c_2#120 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#6)*{c'_1#6 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#184))*{c_1#184 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#121))*{c_2#121 <- `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#7)))*{c'_1#7 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#7)))*{c'_2#7 <- `c'_2*`} + -- if (c_1#185*{c_1#185 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#122*{c_2#122 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#186) =/= ?()))*{c_1#186 <- `c_1*`} + -- if (c'_1#8*{c'_1#8 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#123) =/= ?()))*{c_2#123 <- `c_2*`} + -- if (c'_2#8*{c'_2#8 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#123)))*{c_2#123 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#9)*{c'_1#9 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#187))*{c_1#187 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#124))*{c_2#124 <- `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#10)))*{c'_1#10 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#10)))*{c'_2#10 <- `c'_2*`} + -- if (c_1#188*{c_1#188 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#125*{c_2#125 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#189) =/= ?()))*{c_1#189 <- `c_1*`} + -- if (c'_1#11*{c'_1#11 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#189)))*{c_1#189 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#126) =/= ?()))*{c_2#126 <- `c_2*`} + -- if (c'_2#11*{c'_2#11 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_2#126)))*{c_2#126 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#12)*{c'_1#12 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#190))*{c_1#190 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#127))*{c_2#127 <- `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#13)))*{c'_1#13 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#13)))*{c'_2#13 <- `c'_2*`} + -- if (c_1#191*{c_1#191 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#128*{c_2#128 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#192) =/= ?()))*{c_1#192 <- `c_1*`} + -- if (c'_1#14*{c'_1#14 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#129) =/= ?()))*{c_2#129 <- `c_2*`} + -- if (c'_2#14*{c'_2#14 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#129)))*{c_2#129 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#15)*{c'_1#15 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#193))*{c_1#193 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#130))*{c_2#130 <- `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#16)))*{c'_1#16 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#16)))*{c'_2#16 <- `c'_2*`} + -- if (c_1#194*{c_1#194 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#131*{c_2#131 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#195) =/= ?()))*{c_1#195 <- `c_1*`} + -- if (c'_1#17*{c'_1#17 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#195)))*{c_1#195 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#132) =/= ?()))*{c_2#132 <- `c_2*`} + -- if (c'_2#17*{c'_2#17 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#132)))*{c_2#132 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#18)*{c'_1#18 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#196))*{c_1#196 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#133))*{c_2#133 <- `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#19)))*{c'_1#19 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#19)))*{c'_2#19 <- `c'_2*`} + -- if (c_1#197*{c_1#197 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#134*{c_2#134 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#198) =/= ?()))*{c_1#198 <- `c_1*`} + -- if (c'_1#20*{c'_1#20 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#135) =/= ?()))*{c_2#135 <- `c_2*`} + -- if (c'_2#20*{c'_2#20 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#135)))*{c_2#135 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#21)*{c'_1#21 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#199))*{c_1#199 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#136))*{c_2#136 <- `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#22)))*{c'_1#22 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#22)))*{c'_2#22 <- `c'_2*`} + -- if (c_1#200*{c_1#200 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#137*{c_2#137 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#201) =/= ?()))*{c_1#201 <- `c_1*`} + -- if (c'_1#23*{c'_1#23 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#201)))*{c_1#201 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#138) =/= ?()))*{c_2#138 <- `c_2*`} + -- if (c'_2#23*{c'_2#23 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_2#138)))*{c_2#138 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#24)*{c'_1#24 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#202))*{c_1#202 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#139))*{c_2#139 <- `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#25)))*{c'_1#25 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#25)))*{c'_2#25 <- `c'_2*`} + -- if (c_1#203*{c_1#203 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#140*{c_2#140 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#204) =/= ?()))*{c_1#204 <- `c_1*`} + -- if (c'_1#26*{c'_1#26 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#141) =/= ?()))*{c_2#141 <- `c_2*`} + -- if (c'_2#26*{c'_2#26 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#141)))*{c_2#141 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#27)*{c'_1#27 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#205))*{c_1#205 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#142))*{c_2#142 <- `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#28)))*{c'_1#28 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#28)))*{c'_2#28 <- `c'_2*`} + -- if (c_1#206*{c_1#206 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#143*{c_2#143 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#207) =/= ?()))*{c_1#207 <- `c_1*`} + -- if (c'_1#29*{c'_1#29 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#207)))*{c_1#207 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#144) =/= ?()))*{c_2#144 <- `c_2*`} + -- if (c'_2#29*{c'_2#29 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#144)))*{c_2#144 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#30)*{c'_1#30 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#208))*{c_1#208 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#145))*{c_2#145 <- `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#31)))*{c'_1#31 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#31)))*{c'_2#31 <- `c'_2*`} + -- if (c_1#209*{c_1#209 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#146*{c_2#146 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#210) =/= ?()))*{c_1#210 <- `c_1*`} + -- if (c'_1#32*{c'_1#32 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#147) =/= ?()))*{c_2#147 <- `c_2*`} + -- if (c'_2#32*{c'_2#32 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#147)))*{c_2#147 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#33)*{c'_1#33 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#211))*{c_1#211 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#148))*{c_2#148 <- `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#34)))*{c'_1#34 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#34)))*{c'_2#34 <- `c'_2*`} + -- if (c_1#212*{c_1#212 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#149*{c_2#149 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#213) =/= ?()))*{c_1#213 <- `c_1*`} + -- if (c'_1#35*{c'_1#35 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#213)))*{c_1#213 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#150) =/= ?()))*{c_2#150 <- `c_2*`} + -- if (c'_2#35*{c'_2#35 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_2#150)))*{c_2#150 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#36)*{c'_1#36 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#214))*{c_1#214 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#151))*{c_2#151 <- `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#37)))*{c'_1#37 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#37)))*{c'_2#37 <- `c'_2*`} + -- if (c_1#215*{c_1#215 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#152*{c_2#152 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#216) =/= ?()))*{c_1#216 <- `c_1*`} + -- if (c'_1#38*{c'_1#38 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#216)))*{c_1#216 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#153) =/= ?()))*{c_2#153 <- `c_2*`} + -- if (c'_2#38*{c'_2#38 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#153)))*{c_2#153 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#39)*{c'_1#39 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#217))*{c_1#217 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#154))*{c_2#154 <- `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#40)))*{c'_1#40 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#40)))*{c'_2#40 <- `c'_2*`} + -- if (c_1#218*{c_1#218 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#155*{c_2#155 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#219) =/= ?()))*{c_1#219 <- `c_1*`} + -- if (c'_1#41*{c'_1#41 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#219)))*{c_1#219 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#156) =/= ?()))*{c_2#156 <- `c_2*`} + -- if (c'_2#41*{c'_2#41 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#156)))*{c_2#156 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#42)*{c'_1#42 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#220))*{c_1#220 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#157))*{c_2#157 <- `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#43)))*{c'_1#43 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#43)))*{c'_2#43 <- `c'_2*`} + -- if (c_1#221*{c_1#221 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#158*{c_2#158 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#222) =/= ?()))*{c_1#222 <- `c_1*`} + -- if (c'_1#44*{c'_1#44 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#222)))*{c_1#222 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#159) =/= ?()))*{c_2#159 <- `c_2*`} + -- if (c'_2#44*{c'_2#44 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#159)))*{c_2#159 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#45)*{c'_1#45 <- `c'_1*`} ++ 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, v : uN, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), sx, v_1, v_2, v) + -- wf_uN: `%%`(128, v) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#223))*{c_1#223 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#160))*{c_2#160 <- `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#46)))*{c'_1#46 <- `c'_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#46)))*{c'_2#46 <- `c'_2*`} + -- if (c_1#224*{c_1#224 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c_2#161*{c_2#161 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#225) =/= ?()))*{c_1#225 <- `c_1*`} + -- if (c'_1#47*{c'_1#47 <- `c'_1*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#225)))*{c_1#225 <- `c_1*`}) + -- (if ($proj_lane__2(c_2#162) =/= ?()))*{c_2#162 <- `c_2*`} + -- if (c'_2#47*{c'_2#47 <- `c'_2*`} = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_2#162)))*{c_2#162 <- `c_2*`}) + -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#48)*{c'_1#48 <- `c'_1*`} ++ 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#129288*{i#129288 <- `i*`}) = $iadd_(N, `%`_iN(j_1), `%`_iN(j_2))*{j_1 <- `j_1*`, j_2 <- `j_2*`} + -- (wf_uN: `%%`(N, `%`_uN(j_1#1)))*{j_1#1 <- `j_1*`} + -- (wf_uN: `%%`(N, `%`_uN(j_2#1)))*{j_2#1 <- `j_2*`} + -- if ($concat_(syntax N, [j_1#2 j_2#2]*{j_1#2 <- `j_1*`, j_2#2 <- `j_2*`}) = $proj_uN_0(i#129291).0*{i#129291 <- `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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#314)*{c#314 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#226))*{c_1#226 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#49))*{c'_1#49 <- `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#312)))*{c#312 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#227*{c_1#227 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#50*{c'_1#50 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#228)))*{c_1#228 <- `c_1*`}) + -- if (c#313*{c#313 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#51*{c'_1#51 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#317)*{c#317 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#229))*{c_1#229 <- `c_1*`} + -- (wf_uN: `%%`($lsize($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#315)))*{c#315 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#230*{c_1#230 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#53*{c'_1#53 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#231)))*{c_1#231 <- `c_1*`}) + -- if (c#316*{c#316 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#54*{c'_1#54 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#320)*{c#320 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#232))*{c_1#232 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#55))*{c'_1#55 <- `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#318)))*{c#318 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#233*{c_1#233 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#56*{c'_1#56 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#234)))*{c_1#234 <- `c_1*`}) + -- if (c#319*{c#319 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#57*{c'_1#57 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#323)*{c#323 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#235))*{c_1#235 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#58))*{c'_1#58 <- `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#321)))*{c#321 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#236*{c_1#236 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#59*{c'_1#59 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx, !($proj_lane__2(c_1#237)))*{c_1#237 <- `c_1*`}) + -- if (c#322*{c#322 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#60*{c'_1#60 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#326)*{c#326 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#238))*{c_1#238 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#61))*{c'_1#61 <- `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#324)))*{c#324 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#239*{c_1#239 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#62*{c'_1#62 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#240)))*{c_1#240 <- `c_1*`}) + -- if (c#325*{c#325 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#63*{c'_1#63 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#329)*{c#329 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#241))*{c_1#241 <- `c_1*`} + -- (wf_uN: `%%`($lsize($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#327)))*{c#327 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#242*{c_1#242 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#65*{c'_1#65 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#243)))*{c_1#243 <- `c_1*`}) + -- if (c#328*{c#328 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#66*{c'_1#66 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#332)*{c#332 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#244))*{c_1#244 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#67))*{c'_1#67 <- `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#330)))*{c#330 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#245*{c_1#245 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#68*{c'_1#68 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#246)))*{c_1#246 <- `c_1*`}) + -- if (c#331*{c#331 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#69*{c'_1#69 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#335)*{c#335 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#247))*{c_1#247 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#70))*{c'_1#70 <- `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#333)))*{c#333 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#248*{c_1#248 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#71*{c'_1#71 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx, !($proj_lane__2(c_1#249)))*{c_1#249 <- `c_1*`}) + -- if (c#334*{c#334 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#72*{c'_1#72 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#338)*{c#338 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#250))*{c_1#250 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#73))*{c'_1#73 <- `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#336)))*{c#336 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#251*{c_1#251 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#74*{c'_1#74 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#252)))*{c_1#252 <- `c_1*`}) + -- if (c#337*{c#337 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#75*{c'_1#75 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#341)*{c#341 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#253))*{c_1#253 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#76))*{c'_1#76 <- `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#339)))*{c#339 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#254*{c_1#254 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#77*{c'_1#77 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#255)))*{c_1#255 <- `c_1*`}) + -- if (c#340*{c#340 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#78*{c'_1#78 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#344)*{c#344 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#256))*{c_1#256 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#79))*{c'_1#79 <- `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#342)))*{c#342 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#257*{c_1#257 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#80*{c'_1#80 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#258)))*{c_1#258 <- `c_1*`}) + -- if (c#343*{c#343 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#81*{c'_1#81 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#347)*{c#347 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#259))*{c_1#259 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#82))*{c'_1#82 <- `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#345)))*{c#345 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#260*{c_1#260 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#83*{c'_1#83 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx, !($proj_lane__2(c_1#261)))*{c_1#261 <- `c_1*`}) + -- if (c#346*{c#346 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#84*{c'_1#84 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#350)*{c#350 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#262))*{c_1#262 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#85))*{c'_1#85 <- `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#348)))*{c#348 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#263*{c_1#263 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#86*{c'_1#86 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#264)))*{c_1#264 <- `c_1*`}) + -- if (c#349*{c#349 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#87*{c'_1#87 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#353)*{c#353 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#265))*{c_1#265 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#88))*{c'_1#88 <- `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#351)))*{c#351 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#266*{c_1#266 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#89*{c'_1#89 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#267)))*{c_1#267 <- `c_1*`}) + -- if (c#352*{c#352 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#90*{c'_1#90 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#356)*{c#356 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#268))*{c_1#268 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#91))*{c'_1#91 <- `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#354)))*{c#354 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#269*{c_1#269 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#92*{c'_1#92 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#270)))*{c_1#270 <- `c_1*`}) + -- if (c#355*{c#355 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#93*{c'_1#93 <- `c'_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, `c*` : iN*, `c_1*` : lane_*, `c'_1*` : iN*}(`%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#359)*{c#359 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#271))*{c_1#271 <- `c_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#94))*{c'_1#94 <- `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#357)))*{c#357 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#272*{c_1#272 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) + -- if (c'_1#95*{c'_1#95 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx, !($proj_lane__2(c_1#273)))*{c_1#273 <- `c_1*`}) + -- if (c#358*{c#358 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#96*{c'_1#96 <- `c'_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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + + ;; ../../../../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}: + `%%%%%`(`%`_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))) + +;; ../../../../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*`} + -- (wf_uN: `%%`(N, j_1#3))*{j_1#3 <- `j_1*`} + -- (wf_uN: `%%`(N, j_2#3))*{j_2#3 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#4 j_2#4]*{j_1#4 <- `j_1*`, j_2#4 <- `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*`} + -- (wf_uN: `%%`(N, j_1#5))*{j_1#5 <- `j_1*`} + -- (wf_uN: `%%`(N, j_2#5))*{j_2#5 <- `j_2*`} + -- if ($concat_(syntax iN, [j_1#6 j_2#6]*{j_1#6 <- `j_1*`, j_2#6 <- `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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#362)*{c#362 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#274))*{c_1#274 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#163))*{c_2#163 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#97))*{c'_1#97 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_2#49))*{c'_2#49 <- `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#360)))*{c#360 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#275*{c_1#275 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#164*{c_2#164 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#98*{c'_1#98 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#276)))*{c_1#276 <- `c_1*`}) + -- if (c'_2#50*{c'_2#50 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#165)))*{c_2#165 <- `c_2*`}) + -- if (c#361*{c#361 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#99*{c'_1#99 <- `c'_1*`}, c'_2#51*{c'_2#51 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#365)*{c#365 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#277))*{c_1#277 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#166))*{c_2#166 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#100))*{c'_1#100 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), 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#363)))*{c#363 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#278*{c_1#278 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#167*{c_2#167 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#101*{c'_1#101 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#279)))*{c_1#279 <- `c_1*`}) + -- if (c'_2#53*{c'_2#53 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#168)))*{c_2#168 <- `c_2*`}) + -- if (c#364*{c#364 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#102*{c'_1#102 <- `c'_1*`}, c'_2#54*{c'_2#54 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#368)*{c#368 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#280))*{c_1#280 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#169))*{c_2#169 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#103))*{c'_1#103 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_2#55))*{c'_2#55 <- `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#366)))*{c#366 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#281*{c_1#281 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#170*{c_2#170 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#104*{c'_1#104 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#282)))*{c_1#282 <- `c_1*`}) + -- if (c'_2#56*{c'_2#56 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#171)))*{c_2#171 <- `c_2*`}) + -- if (c#367*{c#367 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#105*{c'_1#105 <- `c'_1*`}, c'_2#57*{c'_2#57 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#371)*{c#371 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#283))*{c_1#283 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#172))*{c_2#172 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_1#106))*{c'_1#106 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I32_Jnn)), c'_2#58))*{c'_2#58 <- `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#369)))*{c#369 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#284*{c_1#284 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#173*{c_2#173 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#107*{c'_1#107 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_1, !($proj_lane__2(c_1#285)))*{c_1#285 <- `c_1*`}) + -- if (c'_2#59*{c'_2#59 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), sx_2, !($proj_lane__2(c_2#174)))*{c_2#174 <- `c_2*`}) + -- if (c#370*{c#370 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I32_Jnn)), c'_1#108*{c'_1#108 <- `c'_1*`}, c'_2#60*{c'_2#60 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#374)*{c#374 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#286))*{c_1#286 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#175))*{c_2#175 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#109))*{c'_1#109 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_2#61))*{c'_2#61 <- `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#372)))*{c#372 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#287*{c_1#287 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#176*{c_2#176 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#110*{c'_1#110 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#288)))*{c_1#288 <- `c_1*`}) + -- if (c'_2#62*{c'_2#62 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#177)))*{c_2#177 <- `c_2*`}) + -- if (c#373*{c#373 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#111*{c'_1#111 <- `c'_1*`}, c'_2#63*{c'_2#63 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#377)*{c#377 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#289))*{c_1#289 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#178))*{c_2#178 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#112))*{c'_1#112 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), 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#375)))*{c#375 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#290*{c_1#290 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#179*{c_2#179 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#113*{c'_1#113 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#291)))*{c_1#291 <- `c_1*`}) + -- if (c'_2#65*{c'_2#65 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#180)))*{c_2#180 <- `c_2*`}) + -- if (c#376*{c#376 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#114*{c'_1#114 <- `c'_1*`}, c'_2#66*{c'_2#66 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#380)*{c#380 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#292))*{c_1#292 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#181))*{c_2#181 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#115))*{c'_1#115 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_2#67))*{c'_2#67 <- `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#378)))*{c#378 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#293*{c_1#293 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#182*{c_2#182 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#116*{c'_1#116 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#294)))*{c_1#294 <- `c_1*`}) + -- if (c'_2#68*{c'_2#68 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#183)))*{c_2#183 <- `c_2*`}) + -- if (c#379*{c#379 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#117*{c'_1#117 <- `c'_1*`}, c'_2#69*{c'_2#69 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#383)*{c#383 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#295))*{c_1#295 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#184))*{c_2#184 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_1#118))*{c'_1#118 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I64_Jnn)), c'_2#70))*{c'_2#70 <- `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#381)))*{c#381 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#296*{c_1#296 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#185*{c_2#185 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#119*{c'_1#119 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_1, !($proj_lane__2(c_1#297)))*{c_1#297 <- `c_1*`}) + -- if (c'_2#71*{c'_2#71 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), sx_2, !($proj_lane__2(c_2#186)))*{c_2#186 <- `c_2*`}) + -- if (c#382*{c#382 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I64_Jnn)), c'_1#120*{c'_1#120 <- `c'_1*`}, c'_2#72*{c'_2#72 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#386)*{c#386 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#298))*{c_1#298 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#187))*{c_2#187 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#121))*{c'_1#121 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_2#73))*{c'_2#73 <- `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#384)))*{c#384 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#299*{c_1#299 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#188*{c_2#188 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#122*{c'_1#122 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#300)))*{c_1#300 <- `c_1*`}) + -- if (c'_2#74*{c'_2#74 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#189)))*{c_2#189 <- `c_2*`}) + -- if (c#385*{c#385 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#123*{c'_1#123 <- `c'_1*`}, c'_2#75*{c'_2#75 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#389)*{c#389 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#301))*{c_1#301 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#190))*{c_2#190 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#124))*{c'_1#124 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_2#76))*{c'_2#76 <- `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#387)))*{c#387 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#302*{c_1#302 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#191*{c_2#191 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#125*{c'_1#125 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#303)))*{c_1#303 <- `c_1*`}) + -- if (c'_2#77*{c'_2#77 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#192)))*{c_2#192 <- `c_2*`}) + -- if (c#388*{c#388 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#126*{c'_1#126 <- `c'_1*`}, c'_2#78*{c'_2#78 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#392)*{c#392 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#304))*{c_1#304 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#193))*{c_2#193 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#127))*{c'_1#127 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_2#79))*{c'_2#79 <- `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#390)))*{c#390 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#305*{c_1#305 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#194*{c_2#194 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#128*{c'_1#128 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#306)))*{c_1#306 <- `c_1*`}) + -- if (c'_2#80*{c'_2#80 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#195)))*{c_2#195 <- `c_2*`}) + -- if (c#391*{c#391 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#129*{c'_1#129 <- `c'_1*`}, c'_2#81*{c'_2#81 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#395)*{c#395 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#307))*{c_1#307 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#196))*{c_2#196 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_1#130))*{c'_1#130 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I8_Jnn)), c'_2#82))*{c'_2#82 <- `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#393)))*{c#393 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#308*{c_1#308 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#197*{c_2#197 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#131*{c'_1#131 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_1, !($proj_lane__2(c_1#309)))*{c_1#309 <- `c_1*`}) + -- if (c'_2#83*{c'_2#83 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), sx_2, !($proj_lane__2(c_2#198)))*{c_2#198 <- `c_2*`}) + -- if (c#394*{c#394 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I8_Jnn)), c'_1#132*{c'_1#132 <- `c'_1*`}, c'_2#84*{c'_2#84 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#398)*{c#398 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#310))*{c_1#310 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#199))*{c_2#199 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#133))*{c'_1#133 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_2#85))*{c'_2#85 <- `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#396)))*{c#396 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))) + -- if (c_1#311*{c_1#311 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#200*{c_2#200 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#134*{c'_1#134 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#312)))*{c_1#312 <- `c_1*`}) + -- if (c'_2#86*{c'_2#86 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#201)))*{c_2#201 <- `c_2*`}) + -- if (c#397*{c#397 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#135*{c'_1#135 <- `c'_1*`}, c'_2#87*{c'_2#87 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#401)*{c#401 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#313))*{c_1#313 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#202))*{c_2#202 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#136))*{c'_1#136 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_2#88))*{c'_2#88 <- `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#399)))*{c#399 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))) + -- if (c_1#314*{c_1#314 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#203*{c_2#203 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#137*{c'_1#137 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#315)))*{c_1#315 <- `c_1*`}) + -- if (c'_2#89*{c'_2#89 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#204)))*{c_2#204 <- `c_2*`}) + -- if (c#400*{c#400 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#138*{c'_1#138 <- `c'_1*`}, c'_2#90*{c'_2#90 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#404)*{c#404 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#316))*{c_1#316 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#205))*{c_2#205 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#139))*{c'_1#139 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_2#91))*{c'_2#91 <- `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#402)))*{c#402 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))) + -- if (c_1#317*{c_1#317 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#206*{c_2#206 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#140*{c'_1#140 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#318)))*{c_1#318 <- `c_1*`}) + -- if (c'_2#92*{c'_2#92 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#207)))*{c_2#207 <- `c_2*`}) + -- if (c#403*{c#403 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#141*{c'_1#141 <- `c'_1*`}, c'_2#93*{c'_2#93 <- `c'_2*`})) + ;; ../../../../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, `c*` : iN*, `c_1*` : lane_*, `c_2*` : lane_*, `c'_1*` : iN*, `c'_2*` : iN*}(`%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#407)*{c#407 <- `c*`}) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#319))*{c_1#319 <- `c_1*`} + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#208))*{c_2#208 <- `c_2*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_1#142))*{c'_1#142 <- `c'_1*`} + -- (wf_uN: `%%`($lsize($lanetype_Jnn(I16_Jnn)), c'_2#94))*{c'_2#94 <- `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#405)))*{c#405 <- `c*`} + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))) + -- if (c_1#320*{c_1#320 <- `c_1*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c_2#209*{c_2#209 <- `c_2*`} = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)[$proj_uN_0(i).0 : $proj_uN_0(k).0]) + -- if (c'_1#143*{c'_1#143 <- `c'_1*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_1, !($proj_lane__2(c_1#321)))*{c_1#321 <- `c_1*`}) + -- if (c'_2#95*{c'_2#95 <- `c'_2*`} = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), sx_2, !($proj_lane__2(c_2#210)))*{c_2#210 <- `c_2*`}) + -- if (c#406*{c#406 <- `c*`} = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1#144*{c'_1#144 <- `c'_1*`}, c'_2#96*{c'_2#96 <- `c'_2*`})) + +;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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 + rule fun_vextbinop___case_17{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 + rule fun_vextbinop___case_18{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 + rule fun_vextbinop___case_19{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 + rule fun_vextbinop___case_20{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 + rule fun_vextbinop___case_21{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 + rule fun_vextbinop___case_22{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 + rule fun_vextbinop___case_23{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 + rule fun_vextbinop___case_24{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 + rule fun_vextbinop___case_25{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 + rule fun_vextbinop___case_26{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 + rule fun_vextbinop___case_27{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 + rule fun_vextbinop___case_28{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 + rule fun_vextbinop___case_29{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 + rule fun_vextbinop___case_30{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 + rule fun_vextbinop___case_31{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 + rule fun_vextbinop___case_32{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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + + ;; ../../../../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}: + `%%%%%%`(`%`_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)) + +;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + + ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) + -- wf_uN: `%%`(128, c) + -- wf_uN: `%%`(128, c') + -- 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)) + -- 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 ($jsizenn(Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) + -- if (M = (2 * M_2)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + +;; ../../../../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) + +;; ../../../../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 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 +relation fun_packfield__before_fun_packfield__case_9: `%%`(storagetype, val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_8{i : uN}: + `%%`(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) + -- wf_fieldval: `%`(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_7{i : uN}: + `%%`(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) + -- wf_fieldval: `%`(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_6{val : val}: + `%%`(I32_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_5{val : val}: + `%%`(I64_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_4{val : val}: + `%%`(F32_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_3{val : val}: + `%%`(F64_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_2{val : val}: + `%%`(V128_storagetype, val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_1{`null?` : null?, heaptype : heaptype, val : val}: + `%%`(REF_storagetype(`null?`, heaptype), val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_0{val : val}: + `%%`(BOT_storagetype, val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_packfield_: `%%%`(storagetype, val, fieldval?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_0{val : val}: + `%%%`(BOT_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_1{`null?` : null?, heaptype : heaptype, val : val}: + `%%%`(REF_storagetype(`null?`, heaptype), val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_2{val : val}: + `%%%`(V128_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_3{val : val}: + `%%%`(F64_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_4{val : val}: + `%%%`(F32_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_5{val : val}: + `%%%`(I64_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_6{val : val}: + `%%%`(I32_storagetype, val, ?($fieldval_val(val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_7{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 + rule fun_packfield__case_8{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))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_9{x0 : storagetype, x1 : val}: + `%%%`(x0, x1, ?()) + -- ~ fun_packfield__before_fun_packfield__case_9: `%%`(x0, x1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_unpackfield__before_fun_unpackfield__case_72: `%%%`(storagetype, sx?, fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_71{sx : sx, i : uN}: + `%%%`(I16_storagetype, ?(sx), PACK_fieldval(I16_packtype, i)) + -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, sx, i)))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_70{sx : sx, i : uN}: + `%%%`(I8_storagetype, ?(sx), PACK_fieldval(I8_packtype, 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 + rule fun_unpackfield__case_69{numtype : numtype, var_0 : num_}: + `%%%`(I32_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_68{numtype : numtype, var_0 : num_}: + `%%%`(I64_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_67{numtype : numtype, var_0 : num_}: + `%%%`(F32_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_66{numtype : numtype, var_0 : num_}: + `%%%`(F64_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_65{numtype : numtype, var_0 : num_}: + `%%%`(V128_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_64{numtype : numtype, var_0 : num_, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_63{numtype : numtype, var_0 : num_}: + `%%%`(BOT_storagetype, ?(), CONST_fieldval(numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_62{vectype : vectype, var_1 : vec_}: + `%%%`(I32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_61{vectype : vectype, var_1 : vec_}: + `%%%`(I64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_60{vectype : vectype, var_1 : vec_}: + `%%%`(F32_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_59{vectype : vectype, var_1 : vec_}: + `%%%`(F64_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_58{vectype : vectype, var_1 : vec_}: + `%%%`(V128_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_57{vectype : vectype, var_1 : vec_, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_56{vectype : vectype, var_1 : vec_}: + `%%%`(BOT_storagetype, ?(), VCONST_fieldval(vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_55{u31 : u31}: + `%%%`(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_54{u31 : u31}: + `%%%`(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_53{u31 : u31}: + `%%%`(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_52{u31 : u31}: + `%%%`(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_51{u31 : u31}: + `%%%`(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_50{u31 : u31, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_49{u31 : u31}: + `%%%`(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_48: + `%%%`(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_47: + `%%%`(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_46: + `%%%`(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_45: + `%%%`(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_44: + `%%%`(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_43{`null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_42: + `%%%`(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_41{structaddr : structaddr}: + `%%%`(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_40{structaddr : structaddr}: + `%%%`(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_39{structaddr : structaddr}: + `%%%`(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_38{structaddr : structaddr}: + `%%%`(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_37{structaddr : structaddr}: + `%%%`(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_36{structaddr : structaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_35{structaddr : structaddr}: + `%%%`(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_34{arrayaddr : arrayaddr}: + `%%%`(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_33{arrayaddr : arrayaddr}: + `%%%`(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_32{arrayaddr : arrayaddr}: + `%%%`(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_31{arrayaddr : arrayaddr}: + `%%%`(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_30{arrayaddr : arrayaddr}: + `%%%`(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_29{arrayaddr : arrayaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_28{arrayaddr : arrayaddr}: + `%%%`(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_27{funcaddr : funcaddr}: + `%%%`(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_26{funcaddr : funcaddr}: + `%%%`(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_25{funcaddr : funcaddr}: + `%%%`(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_24{funcaddr : funcaddr}: + `%%%`(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_23{funcaddr : funcaddr}: + `%%%`(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_22{funcaddr : funcaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_21{funcaddr : funcaddr}: + `%%%`(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_20{exnaddr : exnaddr}: + `%%%`(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_19{exnaddr : exnaddr}: + `%%%`(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_18{exnaddr : exnaddr}: + `%%%`(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_17{exnaddr : exnaddr}: + `%%%`(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_16{exnaddr : exnaddr}: + `%%%`(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_15{exnaddr : exnaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_14{exnaddr : exnaddr}: + `%%%`(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_13{hostaddr : hostaddr}: + `%%%`(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_12{hostaddr : hostaddr}: + `%%%`(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_11{hostaddr : hostaddr}: + `%%%`(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_10{hostaddr : hostaddr}: + `%%%`(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_9{hostaddr : hostaddr}: + `%%%`(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_8{hostaddr : hostaddr, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_7{hostaddr : hostaddr}: + `%%%`(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_6{ref : ref}: + `%%%`(I32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_5{ref : ref}: + `%%%`(I64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_4{ref : ref}: + `%%%`(F32_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_3{ref : ref}: + `%%%`(F64_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_2{ref : ref}: + `%%%`(V128_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_1{ref : ref, `null?` : null?, heaptype : heaptype}: + `%%%`(REF_storagetype(`null?`, heaptype), ?(), `REF.EXTERN`_fieldval(ref)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_0{ref : ref}: + `%%%`(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(ref)) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_unpackfield_: `%%%%`(storagetype, sx?, fieldval, val?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_0{ref : ref}: + `%%%%`(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_1{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 + rule fun_unpackfield__case_2{ref : ref}: + `%%%%`(V128_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_3{ref : ref}: + `%%%%`(F64_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_4{ref : ref}: + `%%%%`(F32_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_5{ref : ref}: + `%%%%`(I64_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_6{ref : ref}: + `%%%%`(I32_storagetype, ?(), `REF.EXTERN`_fieldval(ref), ?(`REF.EXTERN`_val(ref))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_7{hostaddr : hostaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_8{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 + rule fun_unpackfield__case_9{hostaddr : hostaddr}: + `%%%%`(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_10{hostaddr : hostaddr}: + `%%%%`(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_11{hostaddr : hostaddr}: + `%%%%`(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_12{hostaddr : hostaddr}: + `%%%%`(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_13{hostaddr : hostaddr}: + `%%%%`(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(hostaddr), ?(`REF.HOST_ADDR`_val(hostaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_14{exnaddr : exnaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_15{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 + rule fun_unpackfield__case_16{exnaddr : exnaddr}: + `%%%%`(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_17{exnaddr : exnaddr}: + `%%%%`(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_18{exnaddr : exnaddr}: + `%%%%`(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_19{exnaddr : exnaddr}: + `%%%%`(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_20{exnaddr : exnaddr}: + `%%%%`(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(exnaddr), ?(`REF.EXN_ADDR`_val(exnaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_21{funcaddr : funcaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_22{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 + rule fun_unpackfield__case_23{funcaddr : funcaddr}: + `%%%%`(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_24{funcaddr : funcaddr}: + `%%%%`(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_25{funcaddr : funcaddr}: + `%%%%`(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_26{funcaddr : funcaddr}: + `%%%%`(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_27{funcaddr : funcaddr}: + `%%%%`(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(funcaddr), ?(`REF.FUNC_ADDR`_val(funcaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_28{arrayaddr : arrayaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_29{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 + rule fun_unpackfield__case_30{arrayaddr : arrayaddr}: + `%%%%`(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_31{arrayaddr : arrayaddr}: + `%%%%`(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_32{arrayaddr : arrayaddr}: + `%%%%`(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_33{arrayaddr : arrayaddr}: + `%%%%`(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_34{arrayaddr : arrayaddr}: + `%%%%`(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(arrayaddr), ?(`REF.ARRAY_ADDR`_val(arrayaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_35{structaddr : structaddr}: + `%%%%`(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_36{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 + rule fun_unpackfield__case_37{structaddr : structaddr}: + `%%%%`(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_38{structaddr : structaddr}: + `%%%%`(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_39{structaddr : structaddr}: + `%%%%`(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_40{structaddr : structaddr}: + `%%%%`(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_41{structaddr : structaddr}: + `%%%%`(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(structaddr), ?(`REF.STRUCT_ADDR`_val(structaddr))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_42: + `%%%%`(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_43{`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 + rule fun_unpackfield__case_44: + `%%%%`(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_45: + `%%%%`(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_46: + `%%%%`(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_47: + `%%%%`(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_48: + `%%%%`(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval, ?(`REF.NULL_ADDR`_val)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_49{u31 : u31}: + `%%%%`(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_50{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 + rule fun_unpackfield__case_51{u31 : u31}: + `%%%%`(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_52{u31 : u31}: + `%%%%`(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_53{u31 : u31}: + `%%%%`(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_54{u31 : u31}: + `%%%%`(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_55{u31 : u31}: + `%%%%`(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(u31), ?(`REF.I31_NUM`_val(u31))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_56{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 fun_unpackfield__case_57{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 + rule fun_unpackfield__case_58{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 + rule fun_unpackfield__case_59{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 + rule fun_unpackfield__case_60{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 + rule fun_unpackfield__case_61{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 + rule fun_unpackfield__case_62{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 + rule fun_unpackfield__case_63{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 + rule fun_unpackfield__case_64{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 + rule fun_unpackfield__case_65{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 + rule fun_unpackfield__case_66{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 + rule fun_unpackfield__case_67{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 + rule fun_unpackfield__case_68{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 + rule fun_unpackfield__case_69{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 + rule fun_unpackfield__case_70{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 + rule fun_unpackfield__case_71{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)))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_72{x0 : storagetype, x1 : sx?, x2 : fieldval}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_unpackfield__before_fun_unpackfield__case_72: `%%%`(x0, x1, x2) + +;; ../../../../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 +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 +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 +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 +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 +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[$proj_uN_0(x).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[$proj_uN_0(x).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[$proj_uN_0(x).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[$proj_uN_0(x).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[$proj_uN_0(x).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[$proj_uN_0(x).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[$proj_uN_0(x).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[$proj_uN_0(x).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[$proj_uN_0(x).0] + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_with_local: `%%%%`(state, localidx, val, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_local_case_0{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 fun_with_global: `%%%%`(state, globalidx, val, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_global_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.GLOBALS_moduleinst|) + -- 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 fun_with_table: `%%%%%`(state, tableidx, nat, ref, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_table_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.TABLES_moduleinst|) + -- 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 fun_with_tableinst: `%%%%`(state, tableidx, tableinst, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_tableinst_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.TABLES_moduleinst|) + -- 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 fun_with_mem: `%%%%%%`(state, memidx, nat, nat, byte*, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_mem_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.MEMS_moduleinst|) + -- 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 fun_with_meminst: `%%%%`(state, memidx, meminst, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_meminst_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.MEMS_moduleinst|) + -- 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 fun_with_elem: `%%%%`(state, elemidx, ref*, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_elem_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.ELEMS_moduleinst|) + -- 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 fun_with_data: `%%%%`(state, dataidx, byte*, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_data_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.DATAS_moduleinst|) + -- 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))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_with_struct: `%%%%%`(state, structaddr, nat, fieldval, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_struct_case_0{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 fun_with_array: `%%%%%`(state, arrayaddr, nat, fieldval, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_with_array_case_0{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 fun_add_structinst: `%%%`(state, structinst*, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_add_structinst_case_0{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 fun_add_arrayinst: `%%%`(state, arrayinst*, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_add_arrayinst_case_0{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 fun_add_exninst: `%%%`(state, exninst*, state) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_add_exninst_case_0{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 fun_growtable_before_fun_growtable_case_1: `%%%`(tableinst, nat, ref) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growtable_case_0{tableinst : tableinst, n : nat, r : ref, tableinst' : tableinst, at : addrtype, i : uN, `j?` : u64?, rt : reftype, `r'*` : ref*, i' : uN}: + `%%%`(tableinst, n, r) + -- wf_tableinst: `%`(tableinst') + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#3?{j#3 <- `j?`}), rt), REFS r'#3*{r'#3 <- `r'*`}}) + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#5*{r'#5 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#5).0))?{j#5 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +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, at : addrtype, i : uN, `j?` : u64?, rt : reftype, `r'*` : ref*, i' : uN}: + `%%%%`(tableinst, n, r, ?(tableinst')) + -- wf_tableinst: `%`(tableinst') + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#1?{j#1 <- `j?`}), rt), REFS r'#1*{r'#1 <- `r'*`}}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#2?{j#2 <- `j?`}), rt), REFS r'#2*{r'#2 <- `r'*`} ++ r^n{}}) + -- if (tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#3?{j#3 <- `j?`}), rt), REFS r'#3*{r'#3 <- `r'*`}}) + -- if (tableinst' = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i', j#4?{j#4 <- `j?`}), rt), REFS r'#4*{r'#4 <- `r'*`} ++ r^n{}}) + -- if ($proj_uN_0(i').0 = (|r'#5*{r'#5 <- `r'*`}| + n)) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#5).0))?{j#5 <- `j?`} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + + ;; ../../../../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 fun_growmem_before_fun_growmem_case_1: `%%`(meminst, nat) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_growmem_case_0{meminst : meminst, n : nat, meminst' : meminst, at : addrtype, i : uN, `j?` : u64?, `b*` : byte*, i' : uN}: + `%%`(meminst, n) + -- wf_meminst: `%`(meminst') + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#8?{j#8 <- `j?`})), BYTES b#7*{b#7 <- `b*`}}) + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#9?{j#9 <- `j?`})), BYTES b#8*{b#8 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#9*{b#9 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#10).0))?{j#10 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + +;; ../../../../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, at : addrtype, i : uN, `j?` : u64?, `b*` : byte*, i' : uN}: + `%%%`(meminst, n, ?(meminst')) + -- wf_meminst: `%`(meminst') + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#6?{j#6 <- `j?`})), BYTES b#5*{b#5 <- `b*`}}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#7?{j#7 <- `j?`})), BYTES b#6*{b#6 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#8?{j#8 <- `j?`})), BYTES b#7*{b#7 <- `b*`}}) + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j#9?{j#9 <- `j?`})), BYTES b#8*{b#8 <- `b*`} ++ `%`_byte(0)^(n * (64 * $Ki)){}}) + -- if (($proj_uN_0(i').0 : nat <:> rat) = (((|b#9*{b#9 <- `b*`}| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) + (n : nat <:> rat))) + -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#10).0))?{j#10 <- `j?`} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + + ;; ../../../../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.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.38 + 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.33 + 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(?(), $heaptype_deftype(dt))) + -- wf_store: `%`(s) + -- wf_ref: `%`(`REF.STRUCT_ADDR`_ref(a)) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) + -- if (a < |s.STRUCTS_store|) + -- if (s.STRUCTS_store[a].TYPE_structinst = 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))) + -- wf_store: `%`(s) + -- wf_ref: `%`(`REF.ARRAY_ADDR`_ref(a)) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) + -- if (a < |s.ARRAYS_store|) + -- if (s.ARRAYS_store[a].TYPE_arrayinst = 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))) + -- wf_store: `%`(s) + -- wf_ref: `%`(`REF.FUNC_ADDR`_ref(a)) + -- wf_reftype: `%`(REF_reftype(?(), $heaptype_deftype(dt))) + -- if (a < |s.FUNCS_store|) + -- if (s.FUNCS_store[a].TYPE_funcinst = 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)) + -- wf_store: `%`(s) + -- wf_exninst: `%`(exn) + -- wf_ref: `%`(`REF.EXN_ADDR`_ref(a)) + -- wf_reftype: `%`(REF_reftype(?(), EXN_heaptype)) + -- if (a < |s.EXNS_store|) + -- if (s.EXNS_store[a] = exn) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:57.1-58.35 + 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)) + -- 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) + -- Ref_ok: `%|-%:%`(s, ref, REF_reftype(?(), ANY_heaptype)) + -- if (ref =/= `REF.NULL_ADDR`_ref) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:65.1-68.34 + rule sub{s : store, ref : ref, rt : reftype, rt' : reftype}: + `%|-%:%`(s, ref, 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 []}) + -- Ref_ok: `%|-%:%`(s, ref, rt') + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', rt) +} + +;; ../../../../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, $val_num(num), $valtype_numtype(nt)) + -- wf_store: `%`(s) + -- wf_num: `%`(num) + -- Num_ok: `%|-%:%`(s, num, nt) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule vec{s : store, vec : vec, vt : vectype}: + `%|-%:%`(s, $val_vec(vec), $valtype_vectype(vt)) + -- wf_store: `%`(s) + -- wf_vec: `%`(vec) + -- Vec_ok: `%|-%:%`(s, vec, vt) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule ref{s : store, ref : ref, rt : reftype}: + `%|-%:%`(s, $val_ref(ref), $valtype_reftype(rt)) + -- wf_store: `%`(s) + -- wf_ref: `%`(ref) + -- wf_reftype: `%`(rt) + -- Ref_ok: `%|-%:%`(s, ref, 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, $fieldval_val(val), $storagetype_valtype(t)) + -- wf_store: `%`(s) + -- wf_val: `%`(val) + -- wf_valtype: `%`(t) + -- Val_ok: `%|-%:%`(s, val, t) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule packval{s : store, packval : packval, pt : packtype}: + `%|-%:%`(s, $fieldval_packval(packval), $storagetype_packtype(pt)) + -- wf_store: `%`(s) + -- wf_packval: `%`(packval) + -- Packval_ok: `%|-%:%`(s, packval, pt) + +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec +rec { + +;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:103.1-103.84 +relation Externaddr_ok: `%|-%:%`(store, externaddr, externtype) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:105.1-107.28 + rule tag{s : store, a : addr, taginst : taginst}: + `%|-%:%`(s, TAG_externaddr(a), TAG_externtype(taginst.TYPE_taginst)) + -- wf_store: `%`(s) + -- wf_externtype: `%`(TAG_externtype(taginst.TYPE_taginst)) + -- if (a < |s.TAGS_store|) + -- if (s.TAGS_store[a] = taginst) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:109.1-111.34 + rule global{s : store, a : addr, globalinst : globalinst}: + `%|-%:%`(s, GLOBAL_externaddr(a), GLOBAL_externtype(globalinst.TYPE_globalinst)) + -- wf_store: `%`(s) + -- wf_externtype: `%`(GLOBAL_externtype(globalinst.TYPE_globalinst)) + -- if (a < |s.GLOBALS_store|) + -- if (s.GLOBALS_store[a] = globalinst) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:113.1-115.28 + rule mem{s : store, a : addr, meminst : meminst}: + `%|-%:%`(s, MEM_externaddr(a), MEM_externtype(meminst.TYPE_meminst)) + -- wf_store: `%`(s) + -- wf_externtype: `%`(MEM_externtype(meminst.TYPE_meminst)) + -- if (a < |s.MEMS_store|) + -- if (s.MEMS_store[a] = meminst) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:117.1-119.32 + rule table{s : store, a : addr, tableinst : tableinst}: + `%|-%:%`(s, TABLE_externaddr(a), TABLE_externtype(tableinst.TYPE_tableinst)) + -- wf_store: `%`(s) + -- wf_externtype: `%`(TABLE_externtype(tableinst.TYPE_tableinst)) + -- if (a < |s.TABLES_store|) + -- if (s.TABLES_store[a] = tableinst) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:121.1-123.30 + rule func{s : store, a : addr, funcinst : funcinst}: + `%|-%:%`(s, FUNC_externaddr(a), FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) + -- wf_store: `%`(s) + -- wf_externtype: `%`(FUNC_externtype($typeuse_deftype(funcinst.TYPE_funcinst))) + -- if (a < |s.FUNCS_store|) + -- if (s.FUNCS_store[a] = funcinst) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec:125.1-128.37 + rule sub{s : store, externaddr : externaddr, xt : externtype, xt' : externtype}: + `%|-%:%`(s, externaddr, 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 []}) + -- Externaddr_ok: `%|-%:%`(s, externaddr, xt') + -- Externtype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, xt', xt) +} + +;; ../../../../specification/wasm-3.0/4.2-execution.types.spectec +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 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 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 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.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.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}: + `%`([$instr_val(val) BR_ON_NULL_instr(l)]) + -- wf_val: `%`(val) + -- wf_instr: `%`(BR_ON_NULL_instr(l)) + -- wf_instr: `%`(BR_instr(l)) + -- wf_val: `%`(`REF.NULL_ADDR`_val) + -- if (val = `REF.NULL_ADDR`_val) + +;; ../../../../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}: + `%`([$instr_val(val) BR_ON_NON_NULL_instr(l)]) + -- wf_val: `%`(val) + -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) + -- wf_val: `%`(`REF.NULL_ADDR`_val) + -- if (val = `REF.NULL_ADDR`_val) + +;; ../../../../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}: + `%`([$instr_ref(ref) `REF.IS_NULL`_instr]) + -- 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) + -- if (ref = `REF.NULL_ADDR`_ref) + +;; ../../../../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}: + `%`([$instr_ref(ref) `REF.AS_NON_NULL`_instr]) + -- wf_ref: `%`(ref) + -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) + -- wf_instr: `%`(TRAP_instr) + -- wf_ref: `%`(`REF.NULL_ADDR`_ref) + -- if (ref = `REF.NULL_ADDR`_ref) + +;; ../../../../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]) + -- 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) + -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `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}: + `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) + -- 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)))) + -- ~ `Step_pure_before_ref.eq-true`: `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) + -- if (ref_1 = ref_2) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `ref.eq-null_1`{ref_1 : ref, ref_2 : ref}: + `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) + -- 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) + -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `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}: + `%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr]) + -- wf_ref: `%`(ref) + -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) + -- wf_instr: `%`(`REF.NULL_ADDR`_instr) + -- if (ref = `REF.NULL_ADDR`_ref) + +;; ../../../../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}: + `%~>%`([$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*?}: + `%~>%`([$instr_val(val_1) $instr_val(val_2) CONST_instr(I32_numtype, c) SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})], [$instr_val(val_1)]) + -- wf_val: `%`(val_1) + -- wf_val: `%`(val_2) + -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) + -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + + ;; ../../../../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)]) + -- wf_val: `%`(val_1) + -- wf_val: `%`(val_2) + -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- wf_instr: `%`(SELECT_instr(t*{t <- `t*`}?{`t*` <- `t*?`})) + -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + + ;; ../../../../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*`})]) + -- 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*`})) + -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + + ;; ../../../../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*`})]) + -- 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*`})) + -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `label-vals`{n : n, `instr*` : 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'*`}, $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'*`}) + -- 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 ($proj_uN_0(l).0 = 0) + + ;; ../../../../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'*`}, $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)))]) + -- 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)))) + -- if ($proj_uN_0(l).0 > 0) + + ;; ../../../../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*`}, $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)]) + -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- wf_instr: `%`(BR_IF_instr(l)) + -- wf_instr: `%`(BR_instr(l)) + -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 =/= 0) + + ;; ../../../../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)], []) + -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- wf_instr: `%`(BR_IF_instr(l)) + -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = 0) + + ;; ../../../../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_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])) + + ;; ../../../../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')]) + -- wf_instr: `%`(CONST_instr(I32_numtype, i)) + -- wf_instr: `%`(BR_TABLE_instr(l*{l <- `l*`}, l')) + -- wf_instr: `%`(BR_instr(l')) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |l*{l <- `l*`}|) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `br_on_null-null`{val : val, l : labelidx}: + `%~>%`([$instr_val(val) BR_ON_NULL_instr(l)], [BR_instr(l)]) + -- wf_val: `%`(val) + -- wf_instr: `%`(BR_ON_NULL_instr(l)) + -- wf_instr: `%`(BR_instr(l)) + -- wf_val: `%`(`REF.NULL_ADDR`_val) + -- if (val = `REF.NULL_ADDR`_val) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `br_on_null-addr`{val : val, l : labelidx}: + `%~>%`([$instr_val(val) BR_ON_NULL_instr(l)], [$instr_val(val)]) + -- wf_val: `%`(val) + -- wf_instr: `%`(BR_ON_NULL_instr(l)) + -- ~ `Step_pure_before_br_on_null-addr`: `%`([$instr_val(val) BR_ON_NULL_instr(l)]) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `br_on_non_null-null`{val : val, l : labelidx}: + `%~>%`([$instr_val(val) BR_ON_NON_NULL_instr(l)], []) + -- wf_val: `%`(val) + -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) + -- wf_val: `%`(`REF.NULL_ADDR`_val) + -- if (val = `REF.NULL_ADDR`_val) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `br_on_non_null-addr`{val : val, l : labelidx}: + `%~>%`([$instr_val(val) BR_ON_NON_NULL_instr(l)], [$instr_val(val) BR_instr(l)]) + -- wf_val: `%`(val) + -- wf_instr: `%`(BR_ON_NON_NULL_instr(l)) + -- wf_instr: `%`(BR_instr(l)) + -- ~ `Step_pure_before_br_on_non_null-addr`: `%`([$instr_val(val) BR_ON_NON_NULL_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)]) + -- 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: `%`(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)]) + -- 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: `%`(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, $instr_val(val)^n{val <- `val*`})], $instr_val(val)^n{val <- `val*`}) + -- wf_instr: `%`(`FRAME_%{%}%`_instr(n, f, $instr_val(val)^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, $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*`})) + + ;; ../../../../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'*`}, $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*`}, $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*`}, $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*}: + `%~>%`($instr_val(val)*{val <- `val*`} ++ [TRAP_instr] ++ instr*{instr <- `instr*`}, [TRAP_instr]) + -- (wf_val: `%`(val))*{val <- `val*`} + -- (wf_instr: `%`(instr))*{instr <- `instr*`} + -- wf_instr: `%`(TRAP_instr) + -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `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}: + `%~>%`([$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)) + + ;; ../../../../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))))) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `ref.is_null-true`{ref : ref}: + `%~>%`([$instr_ref(ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(1)))]) + -- 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) + -- if (ref = `REF.NULL_ADDR`_ref) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `ref.is_null-false`{ref : ref}: + `%~>%`([$instr_ref(ref) `REF.IS_NULL`_instr], [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))]) + -- wf_ref: `%`(ref) + -- wf_instr: `%`(`REF.IS_NULL`_instr) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(0)))) + -- ~ `Step_pure_before_ref.is_null-false`: `%`([$instr_ref(ref) `REF.IS_NULL`_instr]) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `ref.as_non_null-null`{ref : ref}: + `%~>%`([$instr_ref(ref) `REF.AS_NON_NULL`_instr], [TRAP_instr]) + -- wf_ref: `%`(ref) + -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) + -- wf_instr: `%`(TRAP_instr) + -- wf_ref: `%`(`REF.NULL_ADDR`_ref) + -- if (ref = `REF.NULL_ADDR`_ref) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `ref.as_non_null-addr`{ref : ref}: + `%~>%`([$instr_ref(ref) `REF.AS_NON_NULL`_instr], [$instr_ref(ref)]) + -- wf_ref: `%`(ref) + -- wf_instr: `%`(`REF.AS_NON_NULL`_instr) + -- ~ `Step_pure_before_ref.as_non_null-addr`: `%`([$instr_ref(ref) `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)))]) + -- 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) + -- if ((ref_1 = `REF.NULL_ADDR`_ref) /\ (ref_2 = `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)))]) + -- 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)))) + -- ~ `Step_pure_before_ref.eq-true`: `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) + -- if (ref_1 = ref_2) + + ;; ../../../../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)))]) + -- 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)))) + -- ~ `Step_pure_before_ref.eq-false`: `%`([$instr_ref(ref_1) $instr_ref(ref_2) `REF.EQ`_instr]) + + ;; ../../../../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}: + `%~>%`([$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)) + -- 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}: + `%~>%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr], [`REF.NULL_ADDR`_instr]) + -- wf_ref: `%`(ref) + -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) + -- wf_instr: `%`(`REF.NULL_ADDR`_instr) + -- if (ref = `REF.NULL_ADDR`_ref) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `extern.convert_any-addr`{ref : ref}: + `%~>%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr], [`REF.EXTERN`_instr(ref)]) + -- wf_instr: `%`(`EXTERN.CONVERT_ANY`_instr) + -- wf_instr: `%`(`REF.EXTERN`_instr(ref)) + -- ~ `Step_pure_before_extern.convert_any-addr`: `%`([$instr_ref(ref) `EXTERN.CONVERT_ANY`_instr]) + + ;; ../../../../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], [$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_, var_0 : num_*}: + `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [CONST_instr(nt, c)]) + -- wf_instr: `%`(CONST_instr(nt, c_1)) + -- wf_instr: `%`(UNOP_instr(nt, unop)) + -- wf_instr: `%`(CONST_instr(nt, c)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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_, var_0 : num_*}: + `%~>%`([CONST_instr(nt, c_1) UNOP_instr(nt, unop)], [TRAP_instr]) + -- wf_instr: `%`(CONST_instr(nt, c_1)) + -- wf_instr: `%`(UNOP_instr(nt, unop)) + -- wf_instr: `%`(TRAP_instr) + -- if (var_0 = []) + -- 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_, var_0 : num_*}: + `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [CONST_instr(nt, c)]) + -- 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)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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_, var_0 : num_*}: + `%~>%`([CONST_instr(nt, c_1) CONST_instr(nt, c_2) BINOP_instr(nt, binop)], [TRAP_instr]) + -- wf_instr: `%`(CONST_instr(nt, c_1)) + -- wf_instr: `%`(CONST_instr(nt, c_2)) + -- wf_instr: `%`(BINOP_instr(nt, binop)) + -- wf_instr: `%`(TRAP_instr) + -- if (var_0 = []) + -- 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_, var_0 : u32}: + `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) + -- wf_instr: `%`(CONST_instr(nt, c_1)) + -- wf_instr: `%`(TESTOP_instr(nt, testop)) + -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- if ($proj_num__0(c) =/= ?()) + -- if (!($proj_num__0(c)) = var_0) + -- fun_testop_: `%%%%`(nt, testop, c_1, var_0) + + ;; ../../../../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)]) + -- 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)) + -- if ($proj_num__0(c) =/= ?()) + -- if (!($proj_num__0(c)) = $relop_(nt, relop, c_1, c_2)) + + ;; ../../../../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_, var_0 : num_*}: + `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [CONST_instr(nt_2, c)]) + -- wf_instr: `%`(CONST_instr(nt_1, c_1)) + -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) + -- wf_instr: `%`(CONST_instr(nt_2, c)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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__, var_0 : num_*}: + `%~>%`([CONST_instr(nt_1, c_1) CVTOP_instr(nt_2, nt_1, cvtop)], [TRAP_instr]) + -- wf_instr: `%`(CONST_instr(nt_1, c_1)) + -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) + -- wf_instr: `%`(TRAP_instr) + -- if (var_0 = []) + -- 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)]) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) + -- wf_instr: `%`(VVUNOP_instr(V128_vectype, vvunop)) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- if (|$vvunop_(V128_vectype, vvunop, c_1)| > 0) + -- if (c <- $vvunop_(V128_vectype, vvunop, c_1)) + + ;; ../../../../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)]) + -- 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)) + -- if (|$vvbinop_(V128_vectype, vvbinop, c_1, c_2)| > 0) + -- if (c <- $vvbinop_(V128_vectype, vvbinop, c_1, c_2)) + + ;; ../../../../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)]) + -- 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)) + -- if (|$vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)| > 0) + -- if (c <- $vvternop_(V128_vectype, vvternop, c_1, c_2, c_3)) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule vvtestop{c_1 : vec_, c : num_, var_0 : u32}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) + -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) + -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- if ($proj_num__0(c) =/= ?()) + -- if (!($proj_num__0(c)) = var_0) + -- fun_inez_: `%%%`($vsize(V128_vectype), c_1, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + 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)]) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) + -- wf_instr: `%`(VUNOP_instr(sh, vunop)) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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_, var_0 : vec_*}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VUNOP_instr(sh, vunop)], [TRAP_instr]) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) + -- wf_instr: `%`(VUNOP_instr(sh, vunop)) + -- wf_instr: `%`(TRAP_instr) + -- if (var_0 = []) + -- 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_, var_0 : vec_*}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [VCONST_instr(V128_vectype, c)]) + -- 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)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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_, var_0 : vec_*}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VBINOP_instr(sh, vbinop)], [TRAP_instr]) + -- 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) + -- if (var_0 = []) + -- 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_, 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)]) + -- 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)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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_, 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]) + -- 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) + -- if (var_0 = []) + -- 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_*, `var_0*` : uN*}: + `%~>%`([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)]) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), 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))) + -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) + -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0(var_0).0*{var_0 <- `var_0*`})) + -- if (|`var_0*`| = |`i*`|) + -- (if ($proj_lane__2(i) =/= ?()))*{i <- `i*`} + -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_0))*{var_0 <- `var_0*`, i <- `i*`} + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + 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)]) + -- 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)) + -- if (c = var_0) + -- 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_, var_0 : vec_}: + `%~>%`([VCONST_instr(V128_vectype, c_1) CONST_instr(I32_numtype, i) VSHIFTOP_instr(sh, vshiftop)], [VCONST_instr(V128_vectype, c)]) + -- 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)) + -- if (c = var_0) + -- if ($proj_num__0(i) =/= ?()) + -- 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_, var_0 : u32}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VBITMASK_instr(sh)], [CONST_instr(I32_numtype, c)]) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) + -- wf_instr: `%`(VBITMASK_instr(sh)) + -- wf_instr: `%`(CONST_instr(I32_numtype, c)) + -- if ($proj_num__0(c) =/= ?()) + -- if (!($proj_num__0(c)) = var_0) + -- 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_, var_0 : vec_}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VCONST_instr(V128_vectype, c_2) VSWIZZLOP_instr(sh, swizzlop)], [VCONST_instr(V128_vectype, c)]) + -- 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)) + -- if (c = var_0) + -- 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_, 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)]) + -- 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)) + -- if (c = var_0) + -- 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_, var_0 : lane_}: + `%~>%`([CONST_instr($lunpack(Lnn), c_1) VSPLAT_instr(`%X%`_shape(Lnn, `%`_dim(M)))], [VCONST_instr(V128_vectype, c)]) + -- 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))) + -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), var_0^M{})) + -- fun_lpacknum_: `%%%`(Lnn, c_1, var_0) + + ;; ../../../../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)]) + -- 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)) + -- 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))) + -- 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]) + + ;; ../../../../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)]) + -- 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)) + -- wf_shape: `%`(`%X%`_shape($lanetype_packtype(pt), `%`_dim(M))) + -- 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])))) + + ;; ../../../../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_, var_0 : lane_}: + `%~>%`([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)]) + -- 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))) + -- if (c = $inv_lanes_(`%X%`_shape(Lnn, `%`_dim(M)), $lanes_(`%X%`_shape(Lnn, `%`_dim(M)), c_1)[[$proj_uN_0(i).0] = var_0])) + -- fun_lpacknum_: `%%%`(Lnn, c_2, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + 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)]) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) + -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- if (var_0 = 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_, 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)]) + -- 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)) + -- if (var_0 = 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_, 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)]) + -- 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)) + -- if (var_0 = 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_, 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)]) + -- 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)) + -- if (c = var_0) + -- 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_, var_0 : vec_}: + `%~>%`([VCONST_instr(V128_vectype, c_1) VCVTOP_instr(sh_2, sh_1, vcvtop)], [VCONST_instr(V128_vectype, c)]) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) + -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) + -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) + -- if (c = var_0) + -- fun_vcvtop__: `%%%%%`(sh_1, sh_2, vcvtop, c_1, var_0) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +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*`}))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1#3*{t_1#3 <- `t_1*`}), [], `%`_resulttype(t_2#3*{t_2#3 <- `t_2*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#4*{t_1#4 <- `t_1*`}), `%`_resulttype(t_2#4*{t_2#4 <- `t_2*`}))) + -- Expand: `%~~%`($type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1#5*{t_1#5 <- `t_1*`}), `%`_resulttype(t_2#5*{t_2#5 <- `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?`})))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t#2?{t#2 <- `t?`})))) + +;; ../../../../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, rt : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- wf_reftype: `%`(rt) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- wf_instr: `%`(BR_instr(l)) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Ref_ok: `%|-%:%`(s, ref, rt) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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, rt : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- wf_reftype: `%`(rt) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Ref_ok: `%|-%:%`(s, ref, rt) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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, 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])])) + -- 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-catch_all_0`{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])])) + -- 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_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])])) + -- (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)) + -- 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) + + ;; ../../../../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])])) + -- (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)) + -- 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) + +;; ../../../../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_, 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)])) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + +;; ../../../../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($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), 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)])) + -- ~ `Step_read_before_table.fill-zero`: `%`(`%;%`_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 (n = 0) + + ;; ../../../../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($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), 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)])) + -- wf_instr: `%`(TRAP_instr) + -- if ($proj_num__0(i) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + +;; ../../../../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($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_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) + -- 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|)) + +;; ../../../../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($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)])) + -- ~ `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) + + ;; ../../../../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)])) + -- 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) + -- 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|)) + +;; ../../../../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($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), i_1)) + -- wf_instr: `%`(CONST_instr($numtype_addrtype(at_2), i_2)) + -- wf_instr: `%`(`TABLE.GET`_instr(y)) + -- wf_instr: `%`(`TABLE.SET`_instr(x)) + -- if ($proj_num__0(i_1) =/= ?()) + -- 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))))) + -- if ($proj_num__0(i_2) =/= ?()) + -- 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)) + -- ~ `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) + + ;; ../../../../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($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)])) + -- ~ `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) + + ;; ../../../../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)])) + -- 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) + -- 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|)) + +;; ../../../../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($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_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) + -- 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|)) + +;; ../../../../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($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_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)])) + -- ~ `Step_read_before_table.init-zero`: `%`(`%;%`_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 (n = 0) + + ;; ../../../../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($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_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) + -- 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|)) + +;; ../../../../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($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), 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)])) + -- wf_instr: `%`(TRAP_instr) + -- if ($proj_num__0(i) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + +;; ../../../../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($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), 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)])) + -- ~ `Step_read_before_memory.fill-zero`: `%`(`%;%`_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 (n = 0) + + ;; ../../../../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($numtype_addrtype(at), i) $instr_val(val) CONST_instr($numtype_addrtype(at), 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)])) + -- wf_instr: `%`(TRAP_instr) + -- if ($proj_num__0(i) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + +;; ../../../../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($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_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) + -- 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|)) + +;; ../../../../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($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_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)])) + -- ~ `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) + + ;; ../../../../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)])) + -- 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) + -- 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|)) + +;; ../../../../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, var_0 : memarg}: + `%`(`%;%`_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_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, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) + -- if ($proj_num__0(i_1) =/= ?()) + -- 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))))) + -- if ($proj_num__0(i_2) =/= ?()) + -- 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)) + -- ~ `Step_read_before_memory.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))) `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) + -- fun_memarg0: `%`(var_0) + + ;; ../../../../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($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_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)])) + -- ~ `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) + + ;; ../../../../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($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_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) + -- 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|)) + +;; ../../../../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($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_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) + -- 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|)) + +;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec +relation `Step_read_before_memory.init-succ`: `%`(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($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_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)])) + -- ~ `Step_read_before_memory.init-zero`: `%`(`%;%`_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 (n = 0) + + ;; ../../../../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($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_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) + -- 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|)) + +;; ../../../../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, rt' : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) + -- wf_reftype: `%`(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)))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Ref_ok: `%|-%:%`(s, ref, rt') + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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, rt' : reftype, var_0 : reftype}: + `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- wf_reftype: `%`(rt') + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Ref_ok: `%|-%:%`(s, ref, rt') + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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)])) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + +;; ../../../../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)])) + -- 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)])) + -- ~ `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) + + ;; ../../../../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)])) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + +;; ../../../../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_, 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)])) + -- 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) + -- 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|) + + ;; ../../../../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)])) + -- 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) + -- 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|) + +;; ../../../../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_, 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)])) + -- 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)])) + -- ~ `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) + + ;; ../../../../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)])) + -- 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) + -- 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|) + + ;; ../../../../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)])) + -- 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) + -- 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|) + +;; ../../../../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_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype, var_0 : sx??}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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_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)) + -- if ($proj_num__0(i_1) =/= ?()) + -- wf_instr: `%`(CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(($proj_uN_0(!($proj_num__0(i_1))).0 + 1))))) + -- if ($proj_num__0(i_2) =/= ?()) + -- 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))) + -- ~ `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 (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) + -- fun_sx: `%%`(zt_2, var_0) + + ;; ../../../../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_, 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)])) + -- 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)])) + -- ~ `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) + + ;; ../../../../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)])) + -- 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) + -- 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|) + + ;; ../../../../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)])) + -- 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) + -- 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|) + +;; ../../../../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_, 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)])) + -- 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) + -- if ($proj_num__0(j) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + + ;; ../../../../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)])) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + +;; ../../../../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)])) + -- 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)])) + -- ~ `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) + + ;; ../../../../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)])) + -- 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) + -- if ($proj_num__0(j) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + + ;; ../../../../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)])) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + +;; ../../../../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_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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_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))) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_num__0(j) =/= ?()) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) + + ;; ../../../../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)])) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + +;; ../../../../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_, 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)])) + -- 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)])) + -- ~ `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(n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- if (n = 0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: + `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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_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))) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_num__0(j) =/= ?()) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) + + ;; ../../../../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)])) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + +;; ../../../../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*, 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*`})]) + -- 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 (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `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*, 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*`})]) + -- 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 (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `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, rt : 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)]) + -- wf_reftype: `%`(rt) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- wf_instr: `%`(BR_instr(l)) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Ref_ok: `%|-%:%`(s, ref, rt) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) + -- ~ `Step_read_before_br_on_cast-fail`: `%`(`%;%`_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, rt : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref)]) + -- wf_reftype: `%`(rt) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Ref_ok: `%|-%:%`(s, ref, rt) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(ref) BR_instr(l)]) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) + -- wf_instr: `%`(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)])) + + ;; ../../../../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)|) + -- 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))) + -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) + -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + + ;; ../../../../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*, `var_0*` : val??*}: + `%~>%`(`%;%`_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*`})])]) + -- 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*`})) + -- (if (var_0 =/= ?()))*{var_0 <- `var_0*`} + -- wf_frame: `%`({LOCALS ?(val)^n{val <- `val*`} ++ !(var_0)*{var_0 <- `var_0*`}, MODULE fi.MODULE_funcinst}) + -- 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 (f = {LOCALS ?(val)^n{val <- `val*`} ++ !(var_0)*{var_0 <- `var_0*`}, MODULE fi.MODULE_funcinst}) + -- if (|`var_0*`| = |`t*`|) + -- (fun_default_: `%%`(t, var_0))*{var_0 <- `var_0*`, t <- `t*`} + + ;; ../../../../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)|) + -- 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))) + -- if ($proj_uN_0(x).0 < |$moduleinst(z).FUNCS_moduleinst|) + -- if ($moduleinst(z).FUNCS_moduleinst[$proj_uN_0(x).0] = a) + + ;; ../../../../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'*`}, $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*`}, $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, $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, $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)]) + -- 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 (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*`}))) + + ;; ../../../../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, $instr_val(val)*{val <- `val*`} ++ [`REF.EXN_ADDR`_instr(a)] ++ [THROW_REF_instr] ++ instr*{instr <- `instr*`}), [`REF.EXN_ADDR`_instr(a) THROW_REF_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) + -- if ((val*{val <- `val*`} =/= []) \/ (instr*{instr <- `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])]), $instr_val(val)*{val <- `val*`} ++ [BR_instr(l)]) + -- (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)) + -- 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) + + ;; ../../../../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)]) + -- (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)) + -- 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) + + ;; ../../../../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])]) + -- 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])) + -- ~ `Step_read_before_throw_ref-handler-next`: `%`(`%;%`_config(z, [`HANDLER_%{%}%`_instr(n, [catch] ++ 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*, 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*`})])]) + -- 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 (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1^m{t_1 <- `t_1*`}), [], `%`_resulttype(t_2^n{t_2 <- `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)]) + -- wf_val: `%`(val) + -- wf_config: `%`(`%;%`_config(z, [`LOCAL.GET`_instr(x)])) + -- if ($local(z, x) = ?(val)) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `global.get`{z : state, x : idx, val : val}: + `%~>%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)]), [$instr_val(val)]) + -- wf_val: `%`(val) + -- wf_config: `%`(`%;%`_config(z, [`GLOBAL.GET`_instr(x)])) + -- if ($global(z, x).VALUE_globalinst = val) + + ;; ../../../../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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) `TABLE.GET`_instr(x)])) + -- wf_instr: `%`(TRAP_instr) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + + ;; ../../../../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($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($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($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) + -- 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)) + -- if (|$table(z, x).REFS_tableinst| = n) + -- if ($table(z, x).TYPE_tableinst = `%%%`_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($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]) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$table(z, x).REFS_tableinst|) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `Step_read_before_table.fill-zero`: `%`(`%;%`_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 (n = 0) + + ;; ../../../../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) =/= ?()) + -- 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($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)) + -- ~ `Step_read_before_table.fill-succ`: `%`(`%;%`_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.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]) + -- 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) + -- 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|)) + + ;; ../../../../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($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)])) + -- ~ `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) + + ;; ../../../../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) =/= ?()) + -- 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($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)) + -- ~ `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) + + ;; ../../../../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) =/= ?()) + -- 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))))) + -- 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: `%`(`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((((n : nat <:> int) - (1 : nat <:> int)) : int <:> nat))))) + -- wf_instr: `%`(`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)])) + + ;; ../../../../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]) + -- 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) + -- 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|)) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `Step_read_before_table.init-zero`: `%`(`%;%`_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 (n = 0) + + ;; ../../../../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) =/= ?()) + -- 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($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)) + -- ~ `Step_read_before_table.init-succ`: `%`(`%;%`_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 `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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) + -- wf_instr: `%`(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|) + + ;; ../../../../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)]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) LOAD_instr(nt, ?(), x, ao)])) + -- wf_instr: `%`(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)]) + + ;; ../../../../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]) + -- 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) + -- 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|) + + ;; ../../../../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)))]) + -- 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)))) + -- 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)]) + + ;; ../../../../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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) + -- wf_instr: `%`(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|) + + ;; ../../../../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)]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(), x, ao)])) + -- wf_instr: `%`(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)]) + + ;; ../../../../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]) + -- 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) + -- 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|) + + ;; ../../../../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)]) + -- 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: `%`(VCONST_instr(V128_vectype, c)) + -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(K))) + -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(K))), mk_lane__2_lane_(Jnn, $extend__(M, $jsizenn(Jnn), sx, j))))^K{j <- `j*`} + -- (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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(SPLAT_vloadop_(`%`_sz(N))), x, ao)])) + -- wf_instr: `%`(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|) + + ;; ../../../../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)]) + -- 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))) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(j).0))) + -- 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{})) + + ;; ../../../../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]) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VLOAD_instr(V128_vectype, ?(ZERO_vloadop_(`%`_sz(N))), x, ao)])) + -- wf_instr: `%`(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|) + + ;; ../../../../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)]) + -- wf_uN: `%%`(N, 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)) + -- 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)) + + ;; ../../../../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]) + -- 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) + -- 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|) + + ;; ../../../../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)]) + -- 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))) + -- wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), mk_lane__2_lane_(Jnn, `%`_uN($proj_uN_0(k).0))) + -- 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))])) + + ;; ../../../../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($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n)))]) + -- 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)) + -- if ((n * (64 * $Ki)) = |$mem(z, x).BYTES_meminst|) + -- if ($mem(z, x).TYPE_meminst = `%%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($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]) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$mem(z, x).BYTES_meminst|) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `Step_read_before_memory.fill-zero`: `%`(`%;%`_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 (n = 0) + + ;; ../../../../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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) 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) =/= ?()) + -- 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, var_0)) + -- 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)) + -- ~ `Step_read_before_memory.fill-succ`: `%`(`%;%`_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)])) + -- fun_memarg0: `%`(var_0) + + ;; ../../../../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]) + -- 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) + -- 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|)) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `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) + + ;; ../../../../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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0) 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) =/= ?()) + -- 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, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) + -- 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)) + -- ~ `Step_read_before_memory.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))) `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) + -- fun_memarg0: `%`(var_0) + + ;; ../../../../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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0) 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) =/= ?()) + -- 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, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) + -- 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)) + -- ~ `Step_read_before_memory.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))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- fun_memarg0: `%`(var_0) + + ;; ../../../../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]) + -- 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) + -- 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|)) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `Step_read_before_memory.init-zero`: `%`(`%;%`_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 (n = 0) + + ;; ../../../../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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) 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) =/= ?()) + -- 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)))) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, var_0)) + -- 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)) + -- ~ `Step_read_before_memory.init-succ`: `%`(`%;%`_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)])) + -- fun_memarg0: `%`(var_0) + + ;; ../../../../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[$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, 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)))]) + -- wf_reftype: `%`(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)))) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Ref_ok: `%|-%:%`(s, ref, rt') + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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), [$instr_ref(ref) `REF.TEST`_instr(rt)]), [CONST_instr(I32_numtype, mk_num__0_num_(I32_Inn, `%`_uN(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(0)))) + -- ~ `Step_read_before_ref.test-false`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.TEST`_instr(rt)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `ref.cast-succeed`{s : store, f : frame, ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: + `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [$instr_ref(ref)]) + -- wf_reftype: `%`(rt') + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Ref_ok: `%|-%:%`(s, ref, rt') + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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), [$instr_ref(ref) `REF.CAST`_instr(rt)]), [TRAP_instr]) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + -- wf_instr: `%`(TRAP_instr) + -- ~ `Step_read_before_ref.cast-fail`: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(ref) `REF.CAST`_instr(rt)])) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec + rule `struct.new_default`{z : state, x : idx, `val*` : val*, `mut?*` : mut?*, `zt*` : storagetype*, `var_1*` : valtype*, `var_0*` : val??*}: + `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(val)*{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]) + -- (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*`}))) + -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if (|`var_0*`| = |`val*`|) + -- (if (var_0 =/= ?()))*{var_0 <- `var_0*`} + -- (if (!(var_0) = ?(val)))*{var_0 <- `var_0*`, val <- `val*`} + -- if (|`var_1*`| = |`zt*`|) + -- (fun_unpack: `%%`(zt, var_1))*{var_1 <- `var_1*`, zt <- `zt*`} + -- if (|`var_1*`| = |`var_0*`|) + -- (fun_default_: `%%`(var_1, var_0))*{var_1 <- `var_1*`, var_0 <- `var_0*`} + + ;; ../../../../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?*, var_0 : val?}: + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx?{sx <- `sx?`}, x, i)]), [$instr_val(!(var_0))]) + -- if (var_0 =/= ?()) + -- 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*`}))) + -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) + -- if ($proj_uN_0(i).0 < |$structinst(z)[a].FIELDS_structinst|) + -- if (a < |$structinst(z)|) + -- fun_unpackfield_: `%%%%`(zt*{zt <- `zt*`}[$proj_uN_0(i).0], sx?{sx <- `sx?`}, $structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0], var_0) + + ;; ../../../../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, var_1 : valtype, var_0 : val??}: + `%~>%`(`%;%`_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))]) + -- 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))) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (var_0 =/= ?()) + -- if (!(var_0) = ?(val)) + -- fun_unpack: `%%`(zt, var_1) + -- fun_default_: `%%`(var_1, var_0) + + ;; ../../../../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]) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$elem(z, y).REFS_eleminst|) + + ;; ../../../../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))]) + -- (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))) + -- if ($proj_num__0(i) =/= ?()) + -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : 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, var_0 : nat?}: + `%~>%`(`%;%`_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]) + -- 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))) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_num__0(i) =/= ?()) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) + + ;; ../../../../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?, var_3 : nat?, `var_2*` : lit_*, var_1 : consttype?, `var_0*` : 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)]), var_0^n{var_0 <- `var_0*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) + -- (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))) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (var_3 =/= ?()) + -- if ($proj_num__0(i) =/= ?()) + -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !(var_3)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- fun_zsize: `%%`(zt, var_3) + -- (fun_cunpacknum_: `%%%`(zt, c, var_2))^n{var_2 <- `var_2*`, c <- `c*`} + -- fun_cunpack: `%%`(zt, var_1) + -- (if (var_1 =/= ?()))^n{} + -- (fun_const: `%%%`(!(var_1), var_2, var_0))^n{var_2 <- `var_2*`, var_0 <- `var_0*`} + + ;; ../../../../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]) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + + ;; ../../../../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?, var_0 : val?}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx?{sx <- `sx?`}, x)]), [$instr_val(!(var_0))]) + -- if (var_0 =/= ?()) + -- 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))) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$arrayinst(z)[a].FIELDS_arrayinst|) + -- if (a < |$arrayinst(z)|) + -- if ($proj_num__0(i) =/= ?()) + -- fun_unpackfield_: `%%%%`(zt, sx?{sx <- `sx?`}, $arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0], var_0) + + ;; ../../../../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|)))]) + -- 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|)))) + + ;; ../../../../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) $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) $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.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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `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) + + ;; ../../../../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) =/= ?()) + -- 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))))) + -- 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)) + -- ~ `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)])) + + ;; ../../../../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) $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, [$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]) + -- 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) + -- 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|) + + ;; ../../../../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]) + -- 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) + -- 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|) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `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) + + ;; ../../../../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, var_0 : sx??}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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) =/= ?()) + -- 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_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))) + -- ~ `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 (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) + -- fun_sx: `%%`(zt_2, var_0) + + ;; ../../../../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, var_0 : sx??}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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) =/= ?()) + -- 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))))) + -- 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))))) + -- 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))) + -- ~ `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 (var_0 =/= ?()) + -- if (sx?{sx <- `sx?`} = !(var_0)) + -- fun_sx: `%%`(zt_2, var_0) + + ;; ../../../../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]) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + + ;; ../../../../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]) + -- 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) + -- if ($proj_num__0(j) =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + n) > |$elem(z, y).REFS_eleminst|) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `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) + + ;; ../../../../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) =/= ?()) + -- 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_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: `%`(`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 ($proj_uN_0(!($proj_num__0(j))).0 < |$elem(z, y).REFS_eleminst|) + -- if (ref = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(j))).0]) + + ;; ../../../../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]) + -- 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) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) + + ;; ../../../../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, var_0 : nat?}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) 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.ARRAY_ADDR`_instr(a) 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))) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ($proj_num__0(j) =/= ?()) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) + + ;; ../../../../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)]), []) + -- 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)])) + -- ~ `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(n))) `ARRAY.INIT_DATA`_instr(x, y)])) + -- if (n = 0) + + ;; ../../../../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?, var_3 : nat?, var_2 : lit_, var_1 : consttype?, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 + (((!(var_3) : 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 ($proj_num__0(i) =/= ?()) + -- if ($proj_num__0(j) =/= ?()) + -- if (var_3 =/= ?()) + -- 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_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 + (((!(var_3) : 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))) + -- ~ `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 : (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- fun_zsize: `%%`(zt, var_3) + -- fun_cunpacknum_: `%%%`(zt, c, var_2) + -- fun_cunpack: `%%`(zt, var_1) + -- if (var_1 =/= ?()) + -- fun_const: `%%%`(!(var_1), var_2, var_0) + +;; ../../../../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'*`})) + -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) + -- wf_config: `%`(`%;%`_config(z, instr'*{instr' <- `instr'*`})) + -- Step_pure: `%~>%`(instr*{instr <- `instr*`}, 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'*`})) + -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) + -- wf_config: `%`(`%;%`_config(z, instr'*{instr' <- `instr'*`})) + -- Step_read: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), 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, $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*`})) + -- 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'*`})) + -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_config(z', instr'*{instr' <- `instr'*`})) + -- if ((val*{val <- `val*`} =/= []) \/ (instr_1*{instr_1 <- `instr_1*`} =/= [])) + + ;; ../../../../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'*`})])) + -- 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'*`})) + -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_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'*`})])) + -- 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'*`})) + -- Step: `%~>%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_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'*`})])) + -- 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'*`})) + -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr*{instr <- `instr*`}), `%;%`_config(`%;%`_state(s', f''), instr'*{instr' <- `instr'*`})) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:231.1-235.49 + rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_1 : deftype?, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) + -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) + -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) + -- if (var_1 =/= ?()) + -- Expand: `%~~%`(!(var_1), `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*`}}) + -- fun_as_deftype: `%%`($tag(z, x).TYPE_taginst, var_1) + -- fun_add_exninst: `%%%`(z, [exn], var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:309.1-310.56 + rule `local.set`{z : state, val : val, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `LOCAL.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_local: `%%%%`(z, x, val, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:322.1-323.58 + rule `global.set`{z : state, val : val, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [$instr_val(val) `GLOBAL.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_global: `%%%%`(z, x, val, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.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])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$table(z, x).REFS_tableinst|) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:340.1-342.32 + rule `table.set-val`{z : state, at : addrtype, i : num_, ref : ref, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(ref) `TABLE.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- if ($proj_num__0(i) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$table(z, x).REFS_tableinst|) + -- fun_with_table: `%%%%%`(z, x, $proj_uN_0(!($proj_num__0(i))).0, ref, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:351.1-354.46 + rule `table.grow-succeed`{z : state, ref : ref, at : addrtype, n : n, x : idx, ti : tableinst, var_1 : tableinst?, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_ref(ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `TABLE.GROW`_instr(x)]), `%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- 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(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$table(z, x).REFS_tableinst|)))])) + -- if (var_1 =/= ?()) + -- if (ti = !(var_1)) + -- fun_growtable: `%%%%`($table(z, x), n, ref, var_1) + -- fun_with_tableinst: `%%%%`(z, x, ti, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:356.1-357.87 + 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:417.1-418.51 + rule `elem.drop`{z : state, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_elem: `%%%%`(z, x, [], var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:501.1-504.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])) + -- 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) =/= ?()) + -- 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|) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:506.1-510.29 + rule `store-num-val`{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- if (b*{b <- `b*`} = $nbytes_(nt, c)) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:512.1-515.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])) + -- 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])) + -- 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|) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:517.1-521.52 + rule `store-pack-val`{z : state, at : addrtype, i : num_, Inn : Inn, c : num_, n : n, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_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(var_0, [])) + -- 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(var_0, [])) + -- if ($proj_num__0(c) =/= ?()) + -- if (b*{b <- `b*`} = $ibytes_(n, $wrap__($size($numtype_addrtype(Inn)), n, !($proj_num__0(c))))) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:523.1-526.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])) + -- 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) =/= ?()) + -- 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|) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:528.1-531.31 + rule `vstore-val`{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, `b*` : byte*, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- if (b*{b <- `b*`} = $vbytes_(V128_vectype, c)) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:534.1-537.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])) + -- 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])) + -- 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|) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:539.1-544.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, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_LANE_instr(V128_vectype, `%`_sz(N), x, ao, j)]), `%;%`_config(var_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(var_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_uN: `%%`(N, `%`_uN($proj_uN_0(!($proj_lane__2($lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0)) + -- 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($lanetype_Jnn(Jnn), `%`_dim(M)), c)[$proj_uN_0(j).0]))).0))) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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*`}, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:553.1-556.37 + rule `memory.grow-succeed`{z : state, at : addrtype, n : n, x : idx, mi : meminst, var_1 : meminst?, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN((((|$mem(z, x).BYTES_meminst| : nat <:> rat) / ((64 * $Ki) : nat <:> rat)) : rat <:> nat))))])) + -- wf_config: `%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(n))) `MEMORY.GROW`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [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 (var_1 =/= ?()) + -- if (mi = !(var_1)) + -- fun_growmem: `%%%`($mem(z, x), n, var_1) + -- fun_with_meminst: `%%%%`(z, x, mi, var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:558.1-559.84 + 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:619.1-620.51 + rule `data.drop`{z : state, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [`DATA.DROP`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_data: `%%%%`(z, x, [], var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:700.1-704.65 + rule `struct.new`{z : state, n : n, `val*` : val*, x : idx, si : structinst, a : addr, `mut?*` : mut?*, `zt*` : storagetype*, `var_1*` : fieldval?*, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config(var_0, [`REF.STRUCT_ADDR`_instr(a)])) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`STRUCT.NEW`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [`REF.STRUCT_ADDR`_instr(a)])) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)^n{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- (if (var_1 =/= ?()))^n{var_1 <- `var_1*`} + -- wf_structinst: `%`({TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}}) + -- 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 !(var_1)^n{var_1 <- `var_1*`}}) + -- (fun_packfield_: `%%%`(zt, val, var_1))^n{var_1 <- `var_1*`, val <- `val*`, zt <- `zt*`} + -- fun_add_structinst: `%%%`(z, [si], var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:721.1-722.55 + rule `struct.set-null`{z : state, val : val, x : idx, i : fieldidx}: + `%~>%`(`%;%`_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:724.1-727.46 + rule `struct.set-struct`{z : state, a : addr, val : val, x : idx, i : fieldidx, `zt*` : storagetype*, `mut?*` : mut?*, var_1 : fieldval?, var_0 : state}: + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(val) `STRUCT.SET`_instr(x, i)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- Expand: `%~~%`($type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut?{mut <- `mut?`}, zt)*{`mut?` <- `mut?*`, zt <- `zt*`}))) + -- if ($proj_uN_0(i).0 < |zt*{zt <- `zt*`}|) + -- fun_packfield_: `%%%`(zt*{zt <- `zt*`}[$proj_uN_0(i).0], val, var_1) + -- if (var_1 =/= ?()) + -- fun_with_struct: `%%%%%`(z, a, $proj_uN_0(i).0, !(var_1), var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:740.1-745.65 + rule `array.new_fixed`{z : state, n : n, `val*` : val*, x : idx, ai : arrayinst, a : addr, `mut?` : mut?, zt : storagetype, `var_1*` : fieldval?*, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]), `%;%`_config(var_0, [`REF.ARRAY_ADDR`_instr(a)])) + -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))])) + -- wf_config: `%`(`%;%`_config(var_0, [`REF.ARRAY_ADDR`_instr(a)])) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- (if (var_1 =/= ?()))^n{var_1 <- `var_1*`} + -- wf_arrayinst: `%`({TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}}) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if ((a = |$arrayinst(z)|) /\ (ai = {TYPE $type(z, x), FIELDS !(var_1)^n{var_1 <- `var_1*`}})) + -- (fun_packfield_: `%%%`(zt, val, var_1))^n{var_1 <- `var_1*`, val <- `val*`} + -- fun_add_arrayinst: `%%%`(z, [ai], var_0) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:785.1-786.66 + rule `array.set-null`{z : state, i : num_, val : val, x : idx}: + `%~>%`(`%;%`_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:788.1-790.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])) + -- 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])) + -- if ($proj_num__0(i) =/= ?()) + -- if (a < |$arrayinst(z)|) + -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$arrayinst(z)[a].FIELDS_arrayinst|) + + ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:792.1-795.44 + rule `array.set-array`{z : state, a : addr, i : num_, val : val, x : idx, zt : storagetype, `mut?` : mut?, var_1 : fieldval?, var_0 : state}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)]), `%;%`_config(var_0, [])) + -- wf_config: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(val) `ARRAY.SET`_instr(x)])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- fun_packfield_: `%%%`(zt, val, var_1) + -- if ($proj_num__0(i) =/= ?()) + -- if (var_1 =/= ?()) + -- fun_with_array: `%%%%%`(z, a, $proj_uN_0(!($proj_num__0(i))).0, !(var_1), var_0) +} + +;; ../../../../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''*`})) + -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) + -- wf_config: `%`(`%;%`_config(z'', instr''*{instr'' <- `instr''*`})) + -- wf_config: `%`(`%;%`_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''*`})) +} + +;; ../../../../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*`}) + -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) + -- wf_config: `%`(`%;%`_config(z', $instr_val(val)*{val <- `val*`})) + -- Steps: `%~>*%`(`%;%`_config(z, instr*{instr <- `instr*`}), `%;%`_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.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*, `deftype*` : deftype*, rectype : rectype, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: + `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) + -- 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) + -- wf_uN: `%%`(32, x) + -- if (deftype'#1*{deftype'#1 <- `deftype'*`} = var_0) + -- if (type = TYPE_type(rectype)) + -- if (deftype#1*{deftype#1 <- `deftype*`} = var_1) + -- if ($proj_uN_0(x).0 = |deftype'#3*{deftype'#3 <- `deftype'*`}|) +} + +;; ../../../../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, tagtype : typeuse, taginst : taginst}: + `%%%`(s, tagtype, (s +++ {TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.TAGS_store|)) + -- wf_store: `%`({TAGS [taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) + -- wf_taginst: `%`({TYPE tagtype}) + -- if (taginst = {TYPE 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 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*, s_2 : store, ja : nat, `ja'*` : tagaddr*, s_1 : store, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: + `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) + -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) + -- fun_alloctag: `%%%`(s, tagtype, var_0) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_1) + -- if ((s_1, ja) = var_0) + -- if ((s_2, ja'#1*{ja'#1 <- `ja'*`}) = 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, globaltype : globaltype, val : val, globalinst : globalinst}: + `%%%%`(s, globaltype, val, (s +++ {TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}, |s.GLOBALS_store|)) + -- wf_store: `%`({TAGS [], GLOBALS [globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) + -- wf_globalinst: `%`({TYPE globaltype, VALUE val}) + -- if (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.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*, s_2 : store, ga : nat, `ga'*` : globaladdr*, s_1 : store, 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'*`})) + -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) + -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_1) + -- if ((s_1, ga) = var_0) + -- if ((s_2, ga'#1*{ga'#1 <- `ga'*`}) = var_1) +} + +;; ../../../../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|)) + -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [meminst], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) + -- wf_meminst: `%`({TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j#12?{j#12 <- `j?`})), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) + -- if (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 +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*, s_2 : store, ma : nat, `ma'*` : memaddr*, s_1 : store, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: + `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) + -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) + -- fun_allocmem: `%%%`(s, memtype, var_0) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_1) + -- if ((s_1, ma) = var_0) + -- if ((s_2, ma'#1*{ma'#1 <- `ma'*`}) = 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|)) + -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [tableinst], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) + -- wf_tableinst: `%`({TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j#15?{j#15 <- `j?`}), rt), REFS ref^$proj_uN_0(i).0{}}) + -- if (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 +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*, s_2 : store, ta : nat, `ta'*` : tableaddr*, s_1 : store, 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'*`})) + -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) + -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_1) + -- if ((s_1, ta) = var_0) + -- if ((s_2, ta'#1*{ta'#1 <- `ta'*`}) = var_1) +} + +;; ../../../../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|)) + -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [funcinst], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) + -- wf_funcinst: `%`({TYPE deftype, MODULE moduleinst, CODE funccode}) + -- if (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.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*, s_2 : store, fa : nat, `fa'*` : funcaddr*, s_1 : store, 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'*`})) + -- 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) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_1) + -- if ((s_1, fa) = var_0) + -- if ((s_2, fa'#1*{fa'#1 <- `fa'*`}) = var_1) +} + +;; ../../../../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 + 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|)) + -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) + -- wf_datainst: `%`({BYTES byte#3*{byte#3 <- `byte*`}}) + -- if (datainst = {BYTES byte#4*{byte#4 <- `byte*`}}) + +;; ../../../../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**, s_2 : store, da : nat, `da'*` : dataaddr*, s_1 : store, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: + `%%%%`(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'*`})) + -- 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#11*{b#11 <- `b*`}, var_0) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_1) + -- if ((s_1, da) = var_0) + -- if ((s_2, da'#1*{da'#1 <- `da'*`}) = var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +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|)) + -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [eleminst], STRUCTS [], ARRAYS [], EXNS []}) + -- wf_eleminst: `%`({TYPE elemtype, REFS ref#2*{ref#2 <- `ref*`}}) + -- if (eleminst = {TYPE elemtype, REFS ref#3*{ref#3 <- `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 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**, s_2 : store, ea : nat, `ea'*` : elemaddr*, s_1 : store, 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'*`})) + -- 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) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_1) + -- if ((s_1, ea) = var_0) + -- if ((s_2, ea'#1*{ea'#1 <- `ea'*`}) = var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_allocexport: `%%%`(moduleinst, export, exportinst) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocexport_case_0{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.TAGS_moduleinst|) + -- wf_exportinst: `%`({NAME name, ADDR TAG_externaddr(moduleinst.TAGS_moduleinst[$proj_uN_0(x).0])}) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocexport_case_1{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.GLOBALS_moduleinst|) + -- wf_exportinst: `%`({NAME name, ADDR GLOBAL_externaddr(moduleinst.GLOBALS_moduleinst[$proj_uN_0(x).0])}) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocexport_case_2{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.MEMS_moduleinst|) + -- wf_exportinst: `%`({NAME name, ADDR MEM_externaddr(moduleinst.MEMS_moduleinst[$proj_uN_0(x).0])}) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocexport_case_3{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.TABLES_moduleinst|) + -- wf_exportinst: `%`({NAME name, ADDR TABLE_externaddr(moduleinst.TABLES_moduleinst[$proj_uN_0(x).0])}) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocexport_case_4{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])}) + -- if ($proj_uN_0(x).0 < |moduleinst.FUNCS_moduleinst|) + -- 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 fun_allocexports: `%%%`(moduleinst, export*, exportinst*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_allocexports_case_0{moduleinst : moduleinst, `export*` : export*, `var_0*` : exportinst*}: + `%%%`(moduleinst, export#4*{export#4 <- `export*`}, var_0*{var_0 <- `var_0*`}) + -- if (|`var_0*`| = |`export*`|) + -- (fun_allocexport: `%%%`(moduleinst, export, var_0))*{var_0 <- `var_0*`, export <- `export*`} + +;; ../../../../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 + 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_13 : exportinst*, var_12 : (store, funcaddr*), `var_11*` : elemtype*, var_10 : (store, elemaddr*), var_9 : (store, dataaddr*), `var_8*` : tabletype*, var_7 : (store, tableaddr*), `var_6*` : memtype*, var_5 : (store, memaddr*), `var_4*` : globaltype*, var_3 : (store, globaladdr*), `var_2*` : tagtype*, var_1 : (store, tagaddr*), var_0 : deftype*}: + `%%%%%%%`(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)) + -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_13) + -- (if ($proj_uN_0(x#4).0 < |dt#15*{dt#15 <- `dt*`}|))*{x#4 <- `x*`} + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_12) + -- if (|`var_11*`| = |`elemtype*`|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_11))*{var_11 <- `var_11*`, elemtype#3 <- `elemtype*`} + -- fun_allocelems: `%%%%`(s_5, var_11*{var_11 <- `var_11*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_10) + -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_9) + -- if (|`var_8*`| = |`tabletype*`|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_8))*{var_8 <- `var_8*`, tabletype#160 <- `tabletype*`} + -- fun_alloctables: `%%%%`(s_3, var_8*{var_8 <- `var_8*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_7) + -- if (|`var_6*`| = |`memtype*`|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_6))*{var_6 <- `var_6*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_6*{var_6 <- `var_6*`}, var_5) + -- if (|`var_4*`| = |`globaltype*`|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_4))*{var_4 <- `var_4*`, globaltype#126 <- `globaltype*`} + -- fun_allocglobals: `%%%%`(s_1, var_4*{var_4 <- `var_4*`}, val_G#2*{val_G#2 <- `val_G*`}, var_3) + -- if (|`var_2*`| = |`tagtype*`|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_2))*{var_2 <- `var_2*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_2*{var_2 <- `var_2*`}, var_1) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `type*`}, var_0) + -- wf_store: `%`(s_7) + -- wf_moduleinst: `%`(moduleinst) + -- wf_store: `%`(s_1) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_3) + -- wf_store: `%`(s_4) + -- wf_store: `%`(s_5) + -- wf_store: `%`(s_6) + -- wf_module: `%`(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*`}))) + -- (wf_tag: `%`(TAG_tag(tagtype#78)))*{tagtype#78 <- `tagtype*`} + -- if (|`expr_G*`| = |`globaltype*`|) + -- (wf_global: `%`(GLOBAL_global(globaltype#122, expr_G#1)))*{expr_G#1 <- `expr_G*`, globaltype#122 <- `globaltype*`} + -- (wf_mem: `%`(MEMORY_mem(memtype#122)))*{memtype#122 <- `memtype*`} + -- if (|`expr_T*`| = |`tabletype*`|) + -- (wf_table: `%`(TABLE_table(tabletype#156, expr_T#1)))*{expr_T#1 <- `expr_T*`, tabletype#156 <- `tabletype*`} + -- if (|`expr_F*`| = |`local**`|) + -- if (|`expr_F*`| = |`x*`|) + -- (wf_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 (|`byte**`| = |`datamode*`|) + -- (wf_data: `%`(DATA_data(byte#5*{byte#5 <- `byte*#110`}, datamode#110)))*{`byte*#110` <- `byte**`, datamode#110 <- `datamode*`} + -- if (|`elemmode*`| = |`elemtype*`|) + -- if (|`elemmode*`| = |`expr_E**`|) + -- (wf_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**`} + -- wf_moduleinst: `%`({TYPES [], TAGS aa_I#1*{aa_I#1 <- `aa_I*`} ++ aa#1*{aa#1 <- `aa*`}, GLOBALS ga_I#1*{ga_I#1 <- `ga_I*`} ++ ga#1*{ga#1 <- `ga*`}, MEMS ma_I#1*{ma_I#1 <- `ma_I*`} ++ ma#1*{ma#1 <- `ma*`}, TABLES ta_I#1*{ta_I#1 <- `ta_I*`} ++ ta#1*{ta#1 <- `ta*`}, FUNCS fa_I#1*{fa_I#1 <- `fa_I*`} ++ fa#1*{fa#1 <- `fa*`}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({TYPES dt#8*{dt#8 <- `dt*`}, 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#2*{fa#2 <- `fa*`}, DATAS da#1*{da#1 <- `da*`}, ELEMS ea#1*{ea#1 <- `ea*`}, EXPORTS xi#1*{xi#1 <- `xi*`}}) + -- if (module = MODULE_module(`%`_list(type#3*{type#3 <- `type*`}), `%`_list(import#3*{import#3 <- `import*`}), `%`_list(tag#3*{tag#3 <- `tag*`}), `%`_list(global#5*{global#5 <- `global*`}), `%`_list(mem#5*{mem#5 <- `mem*`}), `%`_list(table#5*{table#5 <- `table*`}), `%`_list(func#4*{func#4 <- `func*`}), `%`_list(data#3*{data#3 <- `data*`}), `%`_list(elem#5*{elem#5 <- `elem*`}), start#5?{start#5 <- `start?`}, `%`_list(export#6*{export#6 <- `export*`}))) + -- if (tag#4*{tag#4 <- `tag*`} = TAG_tag(tagtype#80)*{tagtype#80 <- `tagtype*`}) + -- if (global#6*{global#6 <- `global*`} = GLOBAL_global(globaltype#124, expr_G#2)*{expr_G#2 <- `expr_G*`, globaltype#124 <- `globaltype*`}) + -- if (mem#6*{mem#6 <- `mem*`} = MEMORY_mem(memtype#124)*{memtype#124 <- `memtype*`}) + -- if (table#6*{table#6 <- `table*`} = TABLE_table(tabletype#158, expr_T#2)*{expr_T#2 <- `expr_T*`, tabletype#158 <- `tabletype*`}) + -- if (func#5*{func#5 <- `func*`} = FUNC_func(x#3, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#3 <- `x*`}) + -- if (data#4*{data#4 <- `data*`} = DATA_data(byte#6*{byte#6 <- `byte*#112`}, datamode#112)*{`byte*#112` <- `byte**`, datamode#112 <- `datamode*`}) + -- if (elem#6*{elem#6 <- `elem*`} = ELEM_elem(elemtype#2, expr_E#2*{expr_E#2 <- `expr_E*#2`}, elemmode#232)*{elemmode#232 <- `elemmode*`, elemtype#2 <- `elemtype*`, `expr_E*#2` <- `expr_E**`}) + -- if (aa_I#3*{aa_I#3 <- `aa_I*`} = $tagsxa(externaddr#2*{externaddr#2 <- `externaddr*`})) + -- if (ga_I#3*{ga_I#3 <- `ga_I*`} = $globalsxa(externaddr#3*{externaddr#3 <- `externaddr*`})) + -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`})) + -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = $tablesxa(externaddr#5*{externaddr#5 <- `externaddr*`})) + -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = $funcsxa(externaddr#6*{externaddr#6 <- `externaddr*`})) + -- if (dt#9*{dt#9 <- `dt*`} = var_0) + -- if (fa#3*{fa#3 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#6*{func#6 <- `func*`}|){}) + -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_1) + -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_3) + -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_5) + -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_7) + -- if ((s_5, da#2*{da#2 <- `da*`}) = var_9) + -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_10) + -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_12) + -- if (xi#2*{xi#2 <- `xi*`} = var_13) + -- if (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 fun_rundata_: `%%%`(dataidx, data, instr*) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_rundata__case_0{x : uN, n : nat, `b*` : byte*}: + `%%%`(x, DATA_data(b#12^n{b#12 <- `b*`}, PASSIVE_datamode), []) + + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_rundata__case_1{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)) + +;; ../../../../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^n{e#1 <- `e*`}, PASSIVE_elemmode), []) + + ;; ../../../../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^n{e#2 <- `e*`}, DECLARE_elemmode), [`ELEM.DROP`_instr(x)]) + -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + + ;; ../../../../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^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)) + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../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*, z'' : state, ref : ref, `ref'*` : ref*, z' : state, var_0 : (state, ref*)}: + `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) + -- wf_state: `%`(z'') + -- wf_ref: `%`(ref) + -- (wf_ref: `%`(ref'#5))*{ref'#5 <- `ref'*`} + -- wf_state: `%`(z') + -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) + -- if ((z'', ref'#6*{ref'#6 <- `ref'*`}) = var_0) +} + +;; ../../../../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**, z'' : state, `ref*` : ref*, `ref'**` : ref**, z' : state, 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'**`})) + -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) + -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) + -- wf_state: `%`(z'') + -- (wf_ref: `%`(ref#6))*{ref#6 <- `ref*`} + -- (wf_ref: `%`(ref'#7))*{ref'#7 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`} + -- wf_state: `%`(z') + -- if ((z', ref#7*{ref#7 <- `ref*`}) = var_0) + -- if ((z'', ref'#8*{ref'#8 <- `ref'*#4`}*{`ref'*#4` <- `ref'**`}) = var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +rec { + +;; ../../../../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*, z'' : state, val : val, `val'*` : val*, z' : state, s : store, f : frame, s' : store, a : nat, 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'*`})) + -- 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) + -- wf_state: `%`(z'') + -- wf_val: `%`(val) + -- (wf_val: `%`(val'#3))*{val'#3 <- `val'*`} + -- wf_state: `%`(z') + -- wf_state: `%`(`%;%`_state(s, f)) + -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) + -- Eval_expr: `%;%~>*%;%`(z, expr, z', [val]) + -- if (z' = `%;%`_state(s, f)) + -- if ((s', a) = var_0) + -- if ((z'', val'#4*{val'#4 <- `val'*`}) = var_1) +} + +;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec +relation fun_instantiate: `%%%%`(store, module, externaddr*, config) + ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec + rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_7*` : instr**, `var_6*` : instr**, var_5 : (store, moduleinst), var_4 : (state, ref**), var_3 : (state, ref*), var_2 : (state, val*), var_1 : deftype*, 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?`}))) + -- (if (i_E#2 < |elem#12*{elem#12 <- `elem*`}|))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_7))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`} + -- (if (i_D#2 < |data#11*{data#11 <- `data*`}|))^(i_D#2<|data#10*{data#10 <- `data*`}|){} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_6))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_5) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_4) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_3) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_2) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) + -- wf_state: `%`(z) + -- wf_state: `%`(z') + -- (wf_val: `%`(val_G#3))*{val_G#3 <- `val_G*`} + -- wf_state: `%`(z'') + -- (wf_ref: `%`(ref_T#3))*{ref_T#3 <- `ref_T*`} + -- wf_state: `%`(z''') + -- (wf_ref: `%`(ref_E#3))*{ref_E#3 <- `ref_E*#3`}*{`ref_E*#3` <- `ref_E**`} + -- wf_config: `%`(`%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE moduleinst}), instr_E#1*{instr_E#1 <- `instr_E*`} ++ instr_D#1*{instr_D#1 <- `instr_D*`} ++ lift(instr_S#1?{instr_S#1 <- `instr_S?`}))) + -- wf_moduletype: `%`(`%->%`_moduletype(xt_I#1*{xt_I#1 <- `xt_I*`}, xt_E#1*{xt_E#1 <- `xt_E*`})) + -- wf_module: `%`(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*`}))) + -- if (|`expr_G*`| = |`globaltype*`|) + -- (wf_global: `%`(GLOBAL_global(globaltype#127, expr_G#3)))*{expr_G#3 <- `expr_G*`, globaltype#127 <- `globaltype*`} + -- if (|`expr_T*`| = |`tabletype*`|) + -- (wf_table: `%`(TABLE_table(tabletype#161, expr_T#3)))*{expr_T#3 <- `expr_T*`, tabletype#161 <- `tabletype*`} + -- if (|`byte**`| = |`datamode*`|) + -- (wf_data: `%`(DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)))*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`} + -- if (|`elemmode*`| = |`expr_E**`|) + -- if (|`elemmode*`| = |`reftype*`|) + -- (wf_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*`} + -- (wf_start: `%`(START_start(x#6)))?{x#6 <- `x?`} + -- wf_moduleinst: `%`({TYPES var_0, TAGS [], GLOBALS $globalsxa(externaddr#8*{externaddr#8 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#9*{externaddr#9 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) + -- wf_state: `%`(`%;%`_state(s''', f)) + -- (wf_uN: `%%`(32, `%`_uN(i_D#1)))^(i_D#1<|data#7*{data#7 <- `data*`}|){} + -- (wf_uN: `%%`(32, `%`_uN(i_E#1)))^(i_E#1<|elem#8*{elem#8 <- `elem*`}|){} + -- (wf_instr: `%`(CALL_instr(x#7)))?{x#7 <- `x?`} + -- Module_ok: `|-%:%`(module, `%->%`_moduletype(xt_I#2*{xt_I#2 <- `xt_I*`}, xt_E#2*{xt_E#2 <- `xt_E*`})) + -- if (|`externaddr*`| = |`xt_I*`|) + -- (Externaddr_ok: `%|-%:%`(s, externaddr#10, xt_I#3))*{externaddr#10 <- `externaddr*`, xt_I#3 <- `xt_I*`} + -- if (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#8*{mem#8 <- `mem*`}), `%`_list(table#8*{table#8 <- `table*`}), `%`_list(func#10*{func#10 <- `func*`}), `%`_list(data#8*{data#8 <- `data*`}), `%`_list(elem#9*{elem#9 <- `elem*`}), start#7?{start#7 <- `start?`}, `%`_list(export#9*{export#9 <- `export*`}))) + -- if (global#9*{global#9 <- `global*`} = GLOBAL_global(globaltype#129, expr_G#4)*{expr_G#4 <- `expr_G*`, globaltype#129 <- `globaltype*`}) + -- if (table#9*{table#9 <- `table*`} = TABLE_table(tabletype#163, expr_T#4)*{expr_T#4 <- `expr_T*`, tabletype#163 <- `tabletype*`}) + -- if (data#9*{data#9 <- `data*`} = DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`}) + -- if (elem#10*{elem#10 <- `elem*`} = ELEM_elem(reftype#519, expr_E#4*{expr_E#4 <- `expr_E*#4`}, elemmode#239)*{elemmode#239 <- `elemmode*`, `expr_E*#4` <- `expr_E**`, reftype#519 <- `reftype*`}) + -- if (start#8?{start#8 <- `start?`} = START_start(x#8)?{x#8 <- `x?`}) + -- if (moduleinst_0 = {TYPES var_1, TAGS [], GLOBALS $globalsxa(externaddr#11*{externaddr#11 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#12*{externaddr#12 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) + -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_2) + -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_3) + -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_4) + -- if (z''' = `%;%`_state(s''', f)) + -- if ((s'''', moduleinst) = var_5) + -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_6^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`})) + -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_7^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`})) + -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) + +;; ../../../../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))])) + -- if (funcaddr < |s.FUNCS_store|) + -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val#2)*{val#2 <- `val*`} ++ [`REF.FUNC_ADDR`_instr(funcaddr) CALL_REF_instr($typeuse_deftype(s.FUNCS_store[funcaddr].TYPE_funcinst))])) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1#6*{t_1#6 <- `t_1*`}), `%`_resulttype(t_2#6*{t_2#6 <- `t_2*`}))) + -- Expand: `%~~%`(s.FUNCS_store[funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1#7*{t_1#7 <- `t_1*`}), `%`_resulttype(t_2#7*{t_2#7 <- `t_2*`}))) + -- if (|`t_1*`| = |`val*`|) + -- (Val_ok: `%|-%:%`(s, val#3, t_1#8))*{t_1#8 <- `t_1*`, val#3 <- `val*`} + +;; ../../../../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.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 []}) + -- wf_idctxt: `%`({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 +relation Idctxt_ok: `|-%:OK`(idctxt) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + rule _{I : I, `field**` : char**}: + `|-%:OK`(I) + -- wf_idctxt: `%`(I) + -- (wf_name: `%`(`%`_name(field*{field <- `field*`})))*{`field*` <- `field**`} + -- 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) + +;; ../../../../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) + +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 + 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{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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +relation fun_ordered: `%%`(decl*, bool) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + rule fun_ordered_case_0{`decl*` : decl*}: + `%%`(decl#1*{decl#1 <- `decl*`}, true) + -- if ($importsd(decl#2*{decl#2 <- `decl*`}) = []) + + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + rule fun_ordered_case_1{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*`}) = []))) + +;; ../../../../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) + -- 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($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 (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*`} + -- (Reftype_ok: `%|-%:OK`(C_0, et))*{et <- `et*`} + -- (Localtype_ok: `%|-%:OK`(C_0, lct))*{lct <- `lct*`} + -- (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*`} + +;; ../../../../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)) + -- wf_store: `%`(s) + -- wf_val: `%`(val) + -- wf_localtype: `%`(`%%`_localtype(SET_init, t)) + -- Val_ok: `%|-%:%`(s, val, 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) + -- 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 []}) + -- Reftype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt) + -- (Ref_ok: `%|-%:%`(s, ref, rt))*{ref <- `ref*`} + +;; ../../../../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}) + -- wf_store: `%`(s) + -- wf_externtype: `%`(xt) + -- wf_exportinst: `%`({NAME nm, ADDR xa}) + -- Externaddr_ok: `%|-%:%`(s, xa, xt) + +;; ../../../../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*`}}) + -- 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($typeuse_deftype(deftype_F))))*{deftype_F <- `deftype_F*`} + -- (wf_externtype: `%`(MEM_externtype(memtype)))*{memtype <- `memtype*`} + -- (wf_externtype: `%`(TABLE_externtype(tabletype)))*{tabletype <- `tabletype*`} + -- (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*`} + +;; ../../../../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 []}) + -- 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 []}) + -- Moduleinst_ok: `%|-%:%`(s, moduleinst, C) + -- if (|`lct*`| = |`val?*`|) + -- (Localval_ok: `%|-%:%`(s, val?{val <- `val?`}, lct))*{lct <- `lct*`, `val?` <- `val?*`} + +;; ../../../../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*`}))) + -- 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*`}))) + -- Instr_ok: `%|-%:%`(C, instr, `%->_%%`_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, $instr_ref(ref), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_reftype(rt)]))) + -- wf_store: `%`(s) + -- wf_context: `%`(C) + -- wf_ref: `%`(ref) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([$valtype_reftype(rt)]))) + -- Ref_ok: `%|-%:%`(s, ref, 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*}: + `%;%|-%:%`(s, C, `LABEL_%{%}%`_instr(n, instr'*{instr' <- `instr'*`}, instr*{instr <- `instr*`}), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_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*`}))) + -- 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*`}))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- Frame_ok: `%|-%:%`(s, f, C') + -- Expr_ok2: `%;%|-%:%`(s, C', instr*{instr <- `instr*`}, `%`_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*`}))) + -- 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*`}))) + -- (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*`}))) + + ;; ../../../../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*`}))) + -- 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*`}))) + -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*, 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*`}))) + -- 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*`}))) + -- if (|`init*`| = |`t*`|) + -- (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*`}))) + -- 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*`| = |`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 (var_0 =/= ?()) + -- 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*`}))) + -- 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}: + `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, it') + -- wf_store: `%`(s) + -- wf_context: `%`(C) + -- (wf_instr: `%`(instr))*{instr <- `instr*`} + -- wf_instrtype: `%`(it') + -- wf_instrtype: `%`(it) + -- Instrs_ok2: `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, it) + -- Instrtype_sub: `%|-%<:%`(C, it, it') + -- Instrtype_ok: `%|-%:OK`(C, 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*`}))) + -- 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*`}))) + -- 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*`})) + +;; ../../../../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*`})) + -- wf_store: `%`(s) + -- wf_context: `%`(C) + -- (wf_instr: `%`(instr))*{instr <- `instr*`} + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(t*{t <- `t*`}))) + -- Instrs_ok2: `%;%|-%:%`(s, C, instr*{instr <- `instr*`}, `%->_%%`_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) + -- wf_store: `%`(s) + -- wf_taginst: `%`({TYPE jt}) + -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) + -- Tagtype_ok: `%|-%:OK`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, jt) + +;; ../../../../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)) + -- 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 []}) + -- 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) + +;; ../../../../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))))) + -- 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 []}) + -- 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))) + +;; ../../../../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)) + -- 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 []}) + -- 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*`} + +;; ../../../../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 $funccode_func(func)}, dt) + -- wf_store: `%`(s) + -- wf_context: `%`(C) + -- 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 []}) + -- 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) + +;; ../../../../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*`}}) + -- 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*`}))) + -- 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*`} + +;; ../../../../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*`}}) + -- wf_store: `%`(s) + -- wf_arrayinst: `%`({TYPE dt, FIELDS fv*{fv <- `fv*`}}) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- (Fieldval_ok: `%|-%:%`(s, fv, zt))*{fv <- `fv*`} + +;; ../../../../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*`}}) + -- wf_store: `%`(s) + -- wf_exninst: `%`({TAG ta, FIELDS val*{val <- `val*`}}) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) + -- 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*`} + +;; ../../../../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) + -- wf_fieldval: `%`(fv_1) + -- wf_store: `%`(s) + -- wf_fieldval: `%`(fv_2) + -- wf_fieldval: `%`(fv') + -- ImmutReachable: `%>>_%%`(fv_1, s, fv') + -- ImmutReachable: `%>>_%%`(fv', s, fv_2) + + ;; ../../../../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|) + -- wf_store: `%`(s) + -- wf_fieldval: `%`(`REF.STRUCT_ADDR`_fieldval(a)) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft*{ft <- `ft*`}))) + -- wf_fieldtype: `%`(`%%`_fieldtype(?(), zt)) + -- 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)) + + ;; ../../../../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|) + -- wf_store: `%`(s) + -- wf_fieldval: `%`(`REF.ARRAY_ADDR`_fieldval(a)) + -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(?(), zt))) + -- Expand: `%~~%`(s.ARRAYS_store[a].TYPE_arrayinst, 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, $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)) + + ;; ../../../../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, $fieldval_ref(ref)) + -- wf_store: `%`(s) + -- wf_fieldval: `%`(`REF.EXTERN`_fieldval(ref)) +} + +;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec +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 + 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, var_0 : bool}: + `~%>>_%%`(fv_1, s, fv_2) + -- wf_fieldval: `%`(fv_1) + -- wf_store: `%`(s) + -- wf_fieldval: `%`(fv_2) + -- if var_0 + -- 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) + -- 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*`}}) + -- 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*`} + -- (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*`}}) + +;; ../../../../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'}) + -- wf_globalinst: `%`({TYPE `%%`_globaltype(mut?{mut <- `mut?`}, t), VALUE val}) + -- wf_globalinst: `%`({TYPE `%%`_globaltype(mut?{mut <- `mut?`}, t), VALUE val'}) + -- if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (val = 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'*`}}) + -- 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'*`}}) + -- if (n <= n') + -- if (|b*{b <- `b*`}| <= |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'*`}}) + -- 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'*`}}) + -- if (n <= n') + -- if (|ref*{ref <- `ref*`}| <= |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'*`}}) + -- wf_datainst: `%`({BYTES b*{b <- `b*`}}) + -- wf_datainst: `%`({BYTES b'*{b' <- `b'*`}}) + -- if ((b*{b <- `b*`} = b'*{b' <- `b'*`}) \/ (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'*`}}) + -- wf_eleminst: `%`({TYPE rt, REFS ref*{ref <- `ref*`}}) + -- wf_eleminst: `%`({TYPE rt, REFS ref'*{ref' <- `ref'*`}}) + -- if ((ref*{ref <- `ref*`} = ref'*{ref' <- `ref'*`}) \/ (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'*`}}) + -- 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*`}))) + -- 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?*`} + +;; ../../../../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'*`}}) + -- 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))) + -- Expand: `%~~%`(dt, ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) + -- if (|`fv*`| = |`fv'*`|) + -- (if ((mut?{mut <- `mut?`} = ?(MUT_mut)) \/ (fv = fv')))*{fv <- `fv*`, fv' <- `fv'*`} + +;; ../../../../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') + -- wf_store: `%`(s) + -- wf_store: `%`(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|){} + +;; ../../../../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) + -- wf_context: `%`(C) + -- wf_state: `%`(`%;%`_state(s, f)) + -- Store_ok: `|-%:OK`(s) + -- Frame_ok: `%|-%:%`(s, f, C) + +;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec +relation Config_ok: `|-%:OK`(config) + ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec + rule _{z : state, `instr*` : instr*, C : context, `t*` : valtype*}: + `|-%:OK`(`%;%`_config(z, instr*{instr <- `instr*`})) + -- wf_context: `%`(C) + -- (wf_valtype: `%`(t))*{t <- `t*`} + -- wf_config: `%`(`%;%`_config(z, instr*{instr <- `instr*`})) + -- State_ok: `|-%:%`(z, C) + -- Expr_ok: `%|-%:%`(C, instr*{instr <- `instr*`}, `%`_resulttype(t*{t <- `t*`})) + +;; ../../../../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]))) + -- wf_context: `%`(C) + -- wf_instr: `%`(`GLOBAL.GET`_instr(x)) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([t]))) + -- wf_globaltype: `%`(`%%`_globaltype(?(mut), t)) + -- if ($proj_uN_0(x).0 < |C.GLOBALS_context|) + -- if (C.GLOBALS_context[$proj_uN_0(x).0] = `%%`_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*`}))) + -- 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 []}) + -- 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*`}))) +} + +;; ../../../../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*, s_2 : store, a : nat, `a'*` : addr*, s_1 : store}(syntax X, syntax Y, s, [X] ++ X'#1*{X'#1 <- `X'*`}, [Y] ++ Y'#1*{Y'#1 <- `Y'*`}) = (s_2, [a] ++ a'*{a' <- `a'*`}) + -- wf_store: `%`(s_2) + -- wf_store: `%`(s_1) + -- if ((s_1, a) = $allocX(syntax X, syntax Y, s, X, Y)) + -- if ((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.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) * ($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, 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 + ;; ../../../../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*, 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 + ;; ../../../../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 ($proj_sN_0(x33).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 => $valtype_numtype(nt) + ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec + prod{vt : vectype} vt:Bvectype => $valtype_vectype(vt) + ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec + prod{rt : reftype} rt:Breftype => $valtype_reftype(rt) + +;; ../../../../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 => $storagetype_valtype(t) + ;; ../../../../specification/wasm-3.0/5.2-binary.types.spectec + prod{pt : packtype} pt:Bpacktype => $storagetype_packtype(pt) + +;; ../../../../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(($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 + ;; ../../../../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($proj_uN_0(l).0):Bbyte => `%`_laneidx($proj_uN_0(l).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($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 + 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($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($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($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($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($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($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($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($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($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($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($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($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($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($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 + 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**, 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?`} =/= ?()) \/ (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 + ;; ../../../../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 (((($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 + 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, 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))] + +;; ../../../../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*, 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 + ;; ../../../../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 (($proj_char_0(c).0 =/= 10) /\ ($proj_char_0(c).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, 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 { + +;; ../../../../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{var_0 : m} "nan" => NAN_fNmag(var_0) + -- fun_canon_: `%%`(N, var_0) + ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec + prod{n : n, var_0 : nat?} {{"nan:0x"} {n:Thexnum}} => NAN_fNmag(n) + -- if ((1 <= n) /\ (n < (2 ^ !(var_0)))) + -- fun_signif: `%%`(N, var_0) + +;; ../../../../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[$proj_uN_0(x).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[$proj_uN_0(x).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 => $valtype_numtype(nt) + ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec + prod{vt : vectype} vt:Tvectype => $valtype_vectype(vt) + ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec + prod{rt : reftype} rt:Treftype_(I) => $valtype_reftype(rt) + +;; ../../../../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) => $storagetype_valtype(t) + ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec + prod{pt : packtype} pt:Tpacktype => $storagetype_packtype(pt) + +;; ../../../../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*, 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 + ;; ../../../../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[$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[$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') + +;; ../../../../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[$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 + ;; ../../../../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 "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 +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, 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* + ;; ../../../../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) => ($decl_type(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (import, idctxt)} ``:Timport_(I) => ($decl_import(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (tag, idctxt)} ``:Ttag_(I) => ($decl_tag(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (global, idctxt)} ``:Tglobal_(I) => ($decl_global(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (mem, idctxt)} ``:Tmem_(I) => ($decl_mem(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (table, idctxt)} ``:Ttable_(I) => ($decl_table(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (func, idctxt)} ``:Tfunc_(I) => ($decl_func(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (data, idctxt)} ``:Tdata_(I) => ($decl_data(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (elem, idctxt)} ``:Telem_(I) => ($decl_elem(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + prod{`` : (start, idctxt)} ``:Tstart_(I) => ($decl_start(``.0), ``.1) + ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec + 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, var_1 : bool, 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 var_1 + -- fun_ordered: `%%`(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)* + ;; ../../../../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/11-improve-ids.il b/spectec/test-middlend/specification.exp/12-improve-ids.il similarity index 77% rename from spectec/test-middlend/specification.exp/11-improve-ids.il rename to spectec/test-middlend/specification.exp/12-improve-ids.il index 6dba4ca85a..950ef0df88 100644 --- a/spectec/test-middlend/specification.exp/11-improve-ids.il +++ b/spectec/test-middlend/specification.exp/12-improve-ids.il @@ -244,32 +244,70 @@ syntax i64 = iN syntax i128 = iN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $signif(v_N : N) : nat? +relation fun_signif_before_fun_signif_case_2: `%`(N) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $signif(32) = ?(23) + rule fun_signif_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $signif(64) = ?(52) - def $signif{x0 : N}(x0) = ?() - -- otherwise + rule fun_signif_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $expon(v_N : N) : nat? +relation fun_signif: `%%`(N, nat?) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $expon(32) = ?(8) + rule fun_signif_case_0: + `%%`(32, ?(23)) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $expon(64) = ?(11) - def $expon{x0 : N}(x0) = ?() - -- otherwise + rule fun_signif_case_1: + `%%`(64, ?(52)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_signif_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_signif_before_fun_signif_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_expon_before_fun_expon_case_2: `%`(N) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec +relation fun_expon: `%%`(N, nat?) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_0: + `%%`(32, ?(8)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_1: + `%%`(64, ?(11)) + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec + rule fun_expon_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_expon_before_fun_expon_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $fun_M(v_N : N) : nat +relation fun_M: `%%`(N, nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fun_M{v_N : nat}(v_N) = !($signif(v_N)) + rule fun_M_case_0{v_N : nat, var_0 : nat?}: + `%%`(v_N, !(var_0)) + -- if (var_0 =/= ?()) + -- fun_signif: `%%`(v_N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $E(v_N : N) : nat +relation fun_E: `%%`(N, nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $E{v_N : nat}(v_N) = !($expon(v_N)) + rule fun_E_case_0{v_N : nat, var_0 : nat?}: + `%%`(v_N, !(var_0)) + -- if (var_0 =/= ?()) + -- fun_expon: `%%`(v_N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax exp = int @@ -284,23 +322,28 @@ syntax fNmag = ;; ../../../../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{v_N : N, v_m : m, v_exp : exp}: + rule fNmag_case_0{v_N : N, v_m : m, v_exp : exp, var_1 : nat, var_0 : nat}: `%%`(v_N, NORM_fNmag(v_m, v_exp)) - -- if ((v_m < (2 ^ $fun_M(v_N))) /\ ((((2 : nat <:> int) - ((2 ^ ((($E(v_N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= v_exp) /\ (v_exp <= (((2 ^ ((($E(v_N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) + -- if ((v_m < (2 ^ var_0)) /\ ((((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= v_exp) /\ (v_exp <= (((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) + -- fun_E: `%%`(v_N, var_1) + -- fun_M: `%%`(v_N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_1{v_N : N, v_exp : exp, v_m : m}: + rule fNmag_case_1{v_N : N, v_exp : exp, v_m : m, var_1 : nat, var_0 : nat}: `%%`(v_N, SUBNORM_fNmag(v_m)) - -- if ((v_m < (2 ^ $fun_M(v_N))) /\ (((2 : nat <:> int) - ((2 ^ ((($E(v_N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = v_exp)) + -- if ((v_m < (2 ^ var_0)) /\ (((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = v_exp)) + -- fun_E: `%%`(v_N, var_1) + -- fun_M: `%%`(v_N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rule fNmag_case_2{v_N : N}: `%%`(v_N, INF_fNmag) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_3{v_N : N, v_m : m}: + rule fNmag_case_3{v_N : N, v_m : m, var_0 : nat}: `%%`(v_N, NAN_fNmag(v_m)) - -- if ((1 <= v_m) /\ (v_m < (2 ^ $fun_M(v_N)))) + -- if ((1 <= v_m) /\ (v_m < (2 ^ var_0))) + -- fun_M: `%%`(v_N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax fN = @@ -326,27 +369,33 @@ syntax f32 = fN syntax f64 = fN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $fzero(v_N : N) : fN +relation fun_fzero: `%%`(N, fN) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $fzero{v_N : nat}(v_N) = POS_fN(SUBNORM_fNmag(0)) + rule fun_fzero_case_0{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 -def $fnat(v_N : N, nat : nat) : fN +relation fun_fnat: `%%%`(N, 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))) + rule fun_fnat_case_0{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 -def $fone(v_N : N) : fN +relation fun_fone: `%%`(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))) + rule fun_fone_case_0{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 -def $canon_(v_N : N) : nat +relation fun_canon_: `%%`(N, nat) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $canon_{v_N : nat}(v_N) = (2 ^ (((!($signif(v_N)) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) + rule fun_canon__case_0{v_N : nat, var_0 : nat?}: + `%%`(v_N, (2 ^ (((!(var_0) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + -- if (var_0 =/= ?()) + -- fun_signif: `%%`(v_N, var_0) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax vN = uN @@ -381,45 +430,63 @@ relation wf_char: `%`(char) -- 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, b : byte}([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)) + -- if (|var_0_lst| = |ch_lst|) + -- (fun_utf8: `%%`([ch], var_0))*{var_0 <- var_0_lst, ch <- ch_lst} + + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec:91.6-91.11 + rule fun_utf8_case_1{ch : char, b : byte}: + `%%`([ch], [b]) -- wf_byte: `%`(b) -- wf_byte: `%`(`%`_byte($proj_char_0(ch).0)) -- if ($proj_char_0(ch).0 < 128) -- if (`%`_byte($proj_char_0(ch).0) = b) - ;; ../../../../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]) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(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))) - ;; ../../../../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)) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(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))) - ;; ../../../../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)) + + ;; ../../../../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]) + -- fun_cont: `%%`(b_4, var_2) + -- fun_cont: `%%`(b_3, var_1) + -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(b_3) -- wf_byte: `%`(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))) + -- 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)) } ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec @@ -434,10 +501,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_lst : char*}: + rule name_case_0{char_lst : char*, var_0 : byte*}: `%`(`%`_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 @@ -610,97 +678,128 @@ relation wf_free: `%`(free) -- (wf_uN: `%%`(32, var_9))*{var_9 <- var_9} ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -def $free_opt(var_0 : free?) : free +relation fun_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 []} + rule fun_free_opt_case_0: + `%%`(?(), {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 + rule fun_free_opt_case_1{v_free : free}: + `%%`(?(v_free), v_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(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 []} +;; ../../../../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 []}) -- 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 + 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 -def $free_typeidx(v_typeidx : typeidx) : free +relation fun_free_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 []} + rule fun_free_typeidx_case_0{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 -def $free_funcidx(v_funcidx : funcidx) : free +relation fun_free_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 []} + rule fun_free_funcidx_case_0{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 -def $free_globalidx(v_globalidx : globalidx) : free +relation fun_free_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 []} + rule fun_free_globalidx_case_0{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 -def $free_tableidx(v_tableidx : tableidx) : free +relation fun_free_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 []} + rule fun_free_tableidx_case_0{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 -def $free_memidx(v_memidx : memidx) : free +relation fun_free_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 []} + rule fun_free_memidx_case_0{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 -def $free_elemidx(v_elemidx : elemidx) : free +relation fun_free_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 []} + rule fun_free_elemidx_case_0{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 -def $free_dataidx(v_dataidx : dataidx) : free +relation fun_free_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 []} + rule fun_free_dataidx_case_0{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 -def $free_localidx(v_localidx : localidx) : free +relation fun_free_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 []} + rule fun_free_localidx_case_0{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 -def $free_labelidx(v_labelidx : labelidx) : free +relation fun_free_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 []} + rule fun_free_labelidx_case_0{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 -def $free_tagidx(v_tagidx : tagidx) : free +relation fun_free_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]} + rule fun_free_tagidx_case_0{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 -def $free_externidx(v_externidx : externidx) : free +relation fun_free_externidx: `%%`(externidx, free) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{v_funcidx : uN}(FUNC_externidx(v_funcidx)) = $free_funcidx(v_funcidx) + rule fun_free_externidx_case_0{v_funcidx : uN, var_0 : free}: + `%%`(FUNC_externidx(v_funcidx), var_0) + -- fun_free_funcidx: `%%`(v_funcidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{v_globalidx : uN}(GLOBAL_externidx(v_globalidx)) = $free_globalidx(v_globalidx) + rule fun_free_externidx_case_1{v_globalidx : uN, var_0 : free}: + `%%`(GLOBAL_externidx(v_globalidx), var_0) + -- fun_free_globalidx: `%%`(v_globalidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{v_tableidx : uN}(TABLE_externidx(v_tableidx)) = $free_tableidx(v_tableidx) + rule fun_free_externidx_case_2{v_tableidx : uN, var_0 : free}: + `%%`(TABLE_externidx(v_tableidx), var_0) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{v_memidx : uN}(MEM_externidx(v_memidx)) = $free_memidx(v_memidx) + rule fun_free_externidx_case_3{v_memidx : uN, var_0 : free}: + `%%`(MEM_externidx(v_memidx), var_0) + -- fun_free_memidx: `%%`(v_memidx, var_0) + ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - def $free_externidx{v_tagidx : uN}(TAG_externidx(v_tagidx)) = $free_tagidx(v_tagidx) + rule fun_free_externidx_case_4{v_tagidx : uN, var_0 : free}: + `%%`(TAG_externidx(v_tagidx), var_0) + -- fun_free_tagidx: `%%`(v_tagidx, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec syntax null = @@ -1151,75 +1250,87 @@ syntax Cnn = | V128 ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $ANYREF : reftype +relation fun_ANYREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $ANYREF = REF_reftype(?(NULL_null), ANY_heaptype) + rule fun_ANYREF_case_0: + `%`(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 +relation fun_EQREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EQREF = REF_reftype(?(NULL_null), EQ_heaptype) + rule fun_EQREF_case_0: + `%`(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 +relation fun_I31REF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $I31REF = REF_reftype(?(NULL_null), I31_heaptype) + rule fun_I31REF_case_0: + `%`(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 +relation fun_STRUCTREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $STRUCTREF = REF_reftype(?(NULL_null), STRUCT_heaptype) + rule fun_STRUCTREF_case_0: + `%`(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 +relation fun_ARRAYREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $ARRAYREF = REF_reftype(?(NULL_null), ARRAY_heaptype) + rule fun_ARRAYREF_case_0: + `%`(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 +relation fun_FUNCREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FUNCREF = REF_reftype(?(NULL_null), FUNC_heaptype) + rule fun_FUNCREF_case_0: + `%`(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 +relation fun_EXNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EXNREF = REF_reftype(?(NULL_null), EXN_heaptype) + rule fun_EXNREF_case_0: + `%`(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 +relation fun_EXTERNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $EXTERNREF = REF_reftype(?(NULL_null), EXTERN_heaptype) + rule fun_EXTERNREF_case_0: + `%`(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 +relation fun_NULLREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLREF = REF_reftype(?(NULL_null), NONE_heaptype) + rule fun_NULLREF_case_0: + `%`(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 +relation fun_NULLFUNCREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLFUNCREF = REF_reftype(?(NULL_null), NOFUNC_heaptype) + rule fun_NULLFUNCREF_case_0: + `%`(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 +relation fun_NULLEXNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLEXNREF = REF_reftype(?(NULL_null), NOEXN_heaptype) + rule fun_NULLEXNREF_case_0: + `%`(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 +relation fun_NULLEXTERNREF: `%`(reftype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $NULLEXTERNREF = REF_reftype(?(NULL_null), NOEXTERN_heaptype) + rule fun_NULLEXTERNREF_case_0: + `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) -- wf_reftype: `%`(REF_reftype(?(NULL_null), NOEXTERN_heaptype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1384,35 +1495,95 @@ relation wf_moduletype: `%`(moduletype) -- (wf_externtype: `%`(externtype_lst_0))*{externtype_lst_0 <- externtype_lst_0} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $IN(v_N : N) : Inn? +relation fun_IN_before_fun_IN_case_2: `%`(N) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $IN(32) = ?(I32_Inn) + rule fun_IN_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $IN(64) = ?(I64_Inn) - def $IN{x0 : N}(x0) = ?() - -- otherwise + rule fun_IN_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $FN(v_N : N) : Fnn? +relation fun_IN: `%%`(N, Inn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FN(32) = ?(F32_Fnn) + rule fun_IN_case_0: + `%%`(32, ?(I32_Inn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $FN(64) = ?(F64_Fnn) - def $FN{x0 : N}(x0) = ?() - -- otherwise + rule fun_IN_case_1: + `%%`(64, ?(I64_Inn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_IN_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_IN_before_fun_IN_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $JN(v_N : N) : Jnn? +relation fun_FN_before_fun_FN_case_2: `%`(N) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(8) = ?(I8_Jnn) + rule fun_FN_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_FN_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_FN: `%%`(N, Fnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(16) = ?(I16_Jnn) + rule fun_FN_case_0: + `%%`(32, ?(F32_Fnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(32) = ?(I32_Jnn) + rule fun_FN_case_1: + `%%`(64, ?(F64_Fnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $JN(64) = ?(I64_Jnn) - def $JN{x0 : N}(x0) = ?() - -- otherwise + rule fun_FN_case_2{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_FN_before_fun_FN_case_2: `%`(x0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_JN_before_fun_JN_case_4: `%`(N) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_3: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_2: + `%`(32) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_1: + `%`(16) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_0: + `%`(8) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_JN: `%%`(N, Jnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_0: + `%%`(8, ?(I8_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_1: + `%%`(16, ?(I16_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_2: + `%%`(32, ?(I32_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_3: + `%%`(64, ?(I64_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_JN_case_4{x0 : N}: + `%%`(x0, ?()) + -- ~ fun_JN_before_fun_JN_case_4: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $size(v_numtype : numtype) : nat @@ -1453,23 +1624,69 @@ def $lsize(v_lanetype : lanetype) : nat def $lsize(I16_lanetype) = $psize(I16_packtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $zsize(v_storagetype : storagetype) : nat? +relation fun_zsize_before_fun_zsize_case_7: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_6: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_5: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_4: + `%`(V128_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_zsize: `%%`(storagetype, nat?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(I32_storagetype) = ?($size(I32_numtype)) + rule fun_zsize_case_0: + `%%`(I32_storagetype, ?($size(I32_numtype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(I64_storagetype) = ?($size(I64_numtype)) + rule fun_zsize_case_1: + `%%`(I64_storagetype, ?($size(I64_numtype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(F32_storagetype) = ?($size(F32_numtype)) + rule fun_zsize_case_2: + `%%`(F32_storagetype, ?($size(F32_numtype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(F64_storagetype) = ?($size(F64_numtype)) + rule fun_zsize_case_3: + `%%`(F64_storagetype, ?($size(F64_numtype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(V128_storagetype) = ?($vsize(V128_vectype)) + rule fun_zsize_case_4: + `%%`(V128_storagetype, ?($vsize(V128_vectype))) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $zsize(I8_storagetype) = ?($psize(I8_packtype)) + rule fun_zsize_case_5: + `%%`(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 + rule fun_zsize_case_6: + `%%`(I16_storagetype, ?($psize(I16_packtype))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_zsize_case_7{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_zsize_before_fun_zsize_case_7: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $isize(v_Inn : Inn) : nat @@ -1487,31 +1704,69 @@ def $fsize(v_Fnn : Fnn) : nat def $fsize{v_Fnn : Fnn}(v_Fnn) = $size($numtype_Fnn(v_Fnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_isize(nat : nat) : Inn? +relation fun_inv_isize_before_fun_inv_isize_case_2: `%`(nat) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_isize(32) = ?(I32_Inn) + rule fun_inv_isize_case_1: + `%`(64) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_isize(64) = ?(I64_Inn) - def $inv_isize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_inv_isize_case_0: + `%`(32) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_jsize(nat : nat) : Jnn? +relation fun_inv_isize: `%%`(nat, Inn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize(8) = ?(I8_Jnn) + rule fun_inv_isize_case_0: + `%%`(32, ?(I32_Inn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsize(16) = ?(I16_Jnn) + rule fun_inv_isize_case_1: + `%%`(64, ?(I64_Inn)) + ;; ../../../../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)} + rule fun_inv_isize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_inv_isize_before_fun_inv_isize_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_fsize(nat : nat) : Fnn? +relation fun_inv_jsize: `%%`(nat, Jnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_fsize(32) = ?(F32_Fnn) + rule fun_inv_jsize_case_0: + `%%`(8, ?(I8_Jnn)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_fsize(64) = ?(F64_Fnn) - def $inv_fsize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_inv_jsize_case_1: + `%%`(16, ?(I16_Jnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_jsize_case_2{v_n : nat, var_0 : Inn?}: + `%%`(v_n, $Jnn_addrtype(iter_val#1)?{iter_val#1 <- var_0}) + -- fun_inv_isize: `%%`(v_n, var_0) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(nat) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_1: + `%`(64) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_0: + `%`(32) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_inv_fsize: `%%`(nat, Fnn?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_0: + `%%`(32, ?(F32_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_1: + `%%`(64, ?(F64_Fnn)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_inv_fsize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $sizenn(v_numtype : numtype) : nat @@ -1559,9 +1814,11 @@ def $jsizenn(v_Jnn : Jnn) : nat def $jsizenn{v_Jnn : Jnn}(v_Jnn) = $lsize($lanetype_Jnn(v_Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $inv_jsizenn(nat : nat) : Jnn? +relation fun_inv_jsizenn: `%%`(nat, Jnn?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $inv_jsizenn{v_n : nat}(v_n) = $inv_jsize(v_n) + rule fun_inv_jsizenn_case_0{v_n : nat, var_0 : Jnn?}: + `%%`(v_n, var_0) + -- fun_inv_jsize: `%%`(v_n, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lunpack(v_lanetype : lanetype) : numtype @@ -1579,82 +1836,231 @@ def $lunpack(v_lanetype : lanetype) : numtype def $lunpack(I16_lanetype) = I32_numtype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $unpack(v_storagetype : storagetype) : valtype +relation fun_unpack: `%%`(storagetype, valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(BOT_storagetype) = BOT_valtype + rule fun_unpack_case_0: + `%%`(BOT_storagetype, BOT_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack{null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype)) = REF_valtype(null_opt, v_heaptype) + rule fun_unpack_case_1{null_opt : null?, v_heaptype : heaptype}: + `%%`(REF_storagetype(null_opt, v_heaptype), REF_valtype(null_opt, v_heaptype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(V128_storagetype) = V128_valtype + rule fun_unpack_case_2: + `%%`(V128_storagetype, V128_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(F64_storagetype) = F64_valtype + rule fun_unpack_case_3: + `%%`(F64_storagetype, F64_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(F32_storagetype) = F32_valtype + rule fun_unpack_case_4: + `%%`(F32_storagetype, F32_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(I64_storagetype) = I64_valtype + rule fun_unpack_case_5: + `%%`(I64_storagetype, I64_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(I32_storagetype) = I32_valtype + rule fun_unpack_case_6: + `%%`(I32_storagetype, I32_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(I8_storagetype) = I32_valtype + rule fun_unpack_case_7: + `%%`(I8_storagetype, I32_valtype) -- wf_valtype: `%`(I32_valtype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $unpack(I16_storagetype) = I32_valtype + rule fun_unpack_case_8: + `%%`(I16_storagetype, I32_valtype) -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $nunpack(v_storagetype : storagetype) : numtype? +relation fun_nunpack_before_fun_nunpack_case_6: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_5: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_4: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_2: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_nunpack: `%%`(storagetype, numtype?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(I32_storagetype) = ?(I32_numtype) + rule fun_nunpack_case_0: + `%%`(I32_storagetype, ?(I32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(I64_storagetype) = ?(I64_numtype) + rule fun_nunpack_case_1: + `%%`(I64_storagetype, ?(I64_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(F32_storagetype) = ?(F32_numtype) + rule fun_nunpack_case_2: + `%%`(F32_storagetype, ?(F32_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(F64_storagetype) = ?(F64_numtype) + rule fun_nunpack_case_3: + `%%`(F64_storagetype, ?(F64_numtype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $nunpack(I8_storagetype) = ?(I32_numtype) + rule fun_nunpack_case_4: + `%%`(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 + rule fun_nunpack_case_5: + `%%`(I16_storagetype, ?(I32_numtype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_nunpack_case_6{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_nunpack_before_fun_nunpack_case_6: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $vunpack(v_storagetype : storagetype) : vectype? +relation fun_vunpack_before_fun_vunpack_case_1: `%`(storagetype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $vunpack(V128_storagetype) = ?(V128_vectype) - def $vunpack{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_vunpack_case_0: + `%`(V128_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_vunpack: `%%`(storagetype, vectype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_vunpack_case_0: + `%%`(V128_storagetype, ?(V128_vectype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_vunpack_case_1{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_vunpack_before_fun_vunpack_case_1: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $cunpack(v_storagetype : storagetype) : consttype? +relation fun_cunpack_before_fun_cunpack_case_13: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_12: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_11: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_10: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_9: + `%`(F32_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_8: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_7: + `%`(I32_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I32_storagetype) = ?(I32_consttype) + rule fun_cunpack_case_6: + `%`(I16_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I64_storagetype) = ?(I64_consttype) + rule fun_cunpack_case_5: + `%`(I8_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(F32_storagetype) = ?(F32_consttype) + rule fun_cunpack_case_4: + `%`(V128_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(F64_storagetype) = ?(F64_consttype) + rule fun_cunpack_case_3: + `%`(F64_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(V128_storagetype) = ?(V128_consttype) + rule fun_cunpack_case_2: + `%`(F32_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I8_storagetype) = ?(I32_consttype) + rule fun_cunpack_case_1: + `%`(I64_storagetype) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I16_storagetype) = ?(I32_consttype) + rule fun_cunpack_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_cunpack: `%%`(storagetype, consttype?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I32_storagetype) = ?($consttype_numtype($lunpack(I32_lanetype))) + rule fun_cunpack_case_0: + `%%`(I32_storagetype, ?(I32_consttype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I64_storagetype) = ?($consttype_numtype($lunpack(I64_lanetype))) + rule fun_cunpack_case_1: + `%%`(I64_storagetype, ?(I64_consttype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(F32_storagetype) = ?($consttype_numtype($lunpack(F32_lanetype))) + rule fun_cunpack_case_2: + `%%`(F32_storagetype, ?(F32_consttype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(F64_storagetype) = ?($consttype_numtype($lunpack(F64_lanetype))) + rule fun_cunpack_case_3: + `%%`(F64_storagetype, ?(F64_consttype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I8_storagetype) = ?($consttype_numtype($lunpack(I8_lanetype))) + rule fun_cunpack_case_4: + `%%`(V128_storagetype, ?(V128_consttype)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $cunpack(I16_storagetype) = ?($consttype_numtype($lunpack(I16_lanetype))) - def $cunpack{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_cunpack_case_5: + `%%`(I8_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_6: + `%%`(I16_storagetype, ?(I32_consttype)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_7: + `%%`(I32_storagetype, ?($consttype_numtype($lunpack(I32_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_8: + `%%`(I64_storagetype, ?($consttype_numtype($lunpack(I64_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_9: + `%%`(F32_storagetype, ?($consttype_numtype($lunpack(F32_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_10: + `%%`(F64_storagetype, ?($consttype_numtype($lunpack(F64_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_11: + `%%`(I8_storagetype, ?($consttype_numtype($lunpack(I8_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_12: + `%%`(I16_storagetype, ?($consttype_numtype($lunpack(I16_lanetype)))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_cunpack_case_13{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_cunpack_before_fun_cunpack_case_13: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $minat(v_addrtype : addrtype, v_addrtype_0 : addrtype) : addrtype @@ -1662,20 +2068,33 @@ def $minat(v_addrtype : addrtype, v_addrtype_0 : addrtype) : addrtype 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(v_reftype : reftype, v_reftype_0 : reftype) : reftype +relation fun_diffrt: `%%%`(reftype, 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) + rule fun_diffrt_case_0{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) + rule fun_diffrt_case_1{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 -def $as_deftype(v_typeuse : typeuse) : deftype? +relation fun_as_deftype_before_fun_as_deftype_case_1: `%`(typeuse) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $as_deftype{v_rectype : rectype, v_n : n}(_DEF_typeuse(v_rectype, v_n)) = ?(_DEF_deftype(v_rectype, v_n)) - def $as_deftype{x0 : typeuse}(x0) = ?() - -- otherwise + rule fun_as_deftype_case_0{v_rectype : rectype, v_n : n}: + `%`(_DEF_typeuse(v_rectype, v_n)) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +relation fun_as_deftype: `%%`(typeuse, deftype?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_0{v_rectype : rectype, v_n : n}: + `%%`(_DEF_typeuse(v_rectype, v_n), ?(_DEF_deftype(v_rectype, v_n))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec + rule fun_as_deftype_case_1{x0 : typeuse}: + `%%`(x0, ?()) + -- ~ fun_as_deftype_before_fun_as_deftype_case_1: `%`(x0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rec { @@ -1742,36 +2161,84 @@ def $funcsxt(var_0 : externtype*) : deftype* def $funcsxt{v_externtype : externtype, xt_lst : externtype*}([v_externtype] ++ xt_lst) = $funcsxt(xt_lst) } +;; ../../../../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.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: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:401.1-401.73 -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([], []) = ?(([], [])) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:403.1-403.63 - def $minus_recs{v_n : nat, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*}([REC_typevar(v_n)] ++ tv_lst, [tu_1] ++ tu_lst) = $minus_recs(tv_lst, tu_lst) - ;; ../../../../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*, tv'_lst : typevar*, tu'_lst : typeuse*}([_IDX_typevar(x)] ++ tv_lst, [tu_1] ++ tu_lst) = ?(([_IDX_typevar(x)] ++ tv'_lst, [tu_1] ++ tu'_lst)) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation fun_minus_recs_before_fun_minus_recs_case_3: `%%`(typevar*, typeuse*) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_2{x : uN, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*, tv'_lst : typevar*, tu'_lst : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%`([_IDX_typevar(x)] ++ tv_lst, [tu_1] ++ tu_lst) + -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- tv'_lst} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- tu'_lst} -- wf_typevar: `%`(_IDX_typevar(x)) - -- if ((tv'_lst, tu'_lst) = !($minus_recs(tv_lst, tu_lst))) - def $minus_recs{x0 : typevar*, x1 : typeuse*}(x0, x1) = ?() - -- otherwise + -- if (var_0 =/= ?()) + -- if ((tv'_lst, tu'_lst) = !(var_0)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_1{v_n : nat, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%`([REC_typevar(v_n)] ++ tv_lst, [tu_1] ++ tu_lst) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_0: + `%%`([], []) + +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 +relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_0: + `%%%`([], [], ?(([], []))) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_1{v_n : nat, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%%`([REC_typevar(v_n)] ++ tv_lst, [tu_1] ++ tu_lst, var_0) + -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_2{x : uN, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*, tv'_lst : typevar*, tu'_lst : typeuse*, var_0 : (typevar*, typeuse*)?}: + `%%%`([_IDX_typevar(x)] ++ tv_lst, [tu_1] ++ tu_lst, ?(([_IDX_typevar(x)] ++ tv'_lst, [tu_1] ++ tu'_lst))) + -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_0) + -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- tv'_lst} + -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- tu'_lst} + -- wf_typevar: `%`(_IDX_typevar(x)) + -- if (var_0 =/= ?()) + -- if ((tv'_lst, tu'_lst) = !(var_0)) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + rule fun_minus_recs_case_3{x0 : typevar*, x1 : typeuse*}: + `%%%`(x0, x1, ?()) + -- ~ fun_minus_recs_before_fun_minus_recs_case_3: `%%`(x0, x1) } ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec @@ -1792,107 +2259,206 @@ 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 +;; ../../../../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)) + -- if (var_0 =/= ?()) + -- fun_subst_typevar: `%%%%`(REC_typevar(v_n), tv_lst, tu_lst, 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)) + -- if (var_0 =/= ?()) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(v_typeidx), tv_lst, tu_lst, 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))) + -- if (var_0 =/= ?()) + -- fun_subst_typevar: `%%%%`(REC_typevar(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_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))) + -- if (var_0 =/= ?()) + -- fun_subst_typevar: `%%%%`(_IDX_typevar(v_typeidx), tv_lst, tu_lst, 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_1 : heaptype, 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_1) + -- fun_subst_heaptype: `%%%%`(ht, tv_lst, tu_lst, var_0) + -- wf_reftype: `%`(REF_reftype(null_opt, var_1)) + +;; ../../../../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) -- 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'#5, tv_lst, tu_lst)*{tu'#5 <- 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*, 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: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_1 : storagetype, var_0 : storagetype}: + `%%%%`(`%%`_fieldtype(mut_opt, zt), tv_lst, tu_lst, `%%`_fieldtype(mut_opt, var_0)) + -- fun_subst_storagetype: `%%%%`(zt, tv_lst, tu_lst, var_1) + -- fun_subst_storagetype: `%%%%`(zt, tv_lst, tu_lst, var_0) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut_opt, var_1)) + +;; ../../../../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_1_lst : fieldtype*, var_0_lst : fieldtype*}: + `%%%%`(STRUCT_comptype(`%`_list(ft_lst)), tv_lst, tu_lst, STRUCT_comptype(`%`_list(var_0_lst))) + -- if (|var_1_lst| = |ft_lst|) + -- (fun_subst_fieldtype: `%%%%`(ft#2, tv_lst, tu_lst, var_1))*{var_1 <- var_1_lst, ft#2 <- ft_lst} + -- if (|var_0_lst| = |ft_lst|) + -- (fun_subst_fieldtype: `%%%%`(ft, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, ft <- ft_lst} + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1_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_1 : fieldtype, var_0 : fieldtype}: + `%%%%`(ARRAY_comptype(ft), tv_lst, tu_lst, ARRAY_comptype(var_0)) + -- fun_subst_fieldtype: `%%%%`(ft, tv_lst, tu_lst, var_1) + -- fun_subst_fieldtype: `%%%%`(ft, tv_lst, tu_lst, var_0) + -- wf_comptype: `%`(ARRAY_comptype(var_1)) + + ;; ../../../../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_3_lst : valtype*, var_2_lst : valtype*, var_1_lst : valtype*, var_0_lst : valtype*}: + `%%%%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)), tv_lst, tu_lst, `FUNC%->%`_comptype(`%`_resulttype(var_0_lst), `%`_resulttype(var_1_lst))) + -- if (|var_3_lst| = |t_2_lst|) + -- (fun_subst_valtype: `%%%%`(t_2#2, tv_lst, tu_lst, var_3))*{var_3 <- var_3_lst, t_2#2 <- t_2_lst} + -- if (|var_2_lst| = |t_1_lst|) + -- (fun_subst_valtype: `%%%%`(t_1#2, tv_lst, tu_lst, var_2))*{var_2 <- var_2_lst, t_1#2 <- t_1_lst} + -- if (|var_1_lst| = |t_2_lst|) + -- (fun_subst_valtype: `%%%%`(t_2, tv_lst, tu_lst, var_1))*{var_1 <- var_1_lst, t_2 <- t_2_lst} + -- if (|var_0_lst| = |t_1_lst|) + -- (fun_subst_valtype: `%%%%`(t_1, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, t_1 <- t_1_lst} + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2_lst), `%`_resulttype(var_3_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_3 : comptype, var_2_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_3) + -- if (|var_2_lst| = |tu'_lst|) + -- (fun_subst_typeuse: `%%%%`(tu'#5, tv_lst, tu_lst, var_2))*{var_2 <- var_2_lst, tu'#5 <- tu'_lst} + -- fun_subst_comptype: `%%%%`(ct, tv_lst, tu_lst, var_1) + -- if (|var_0_lst| = |tu'_lst|) + -- (fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, tu' <- tu'_lst} + -- wf_subtype: `%`(SUB_subtype(final_opt, var_2_lst, var_3)) + +;; ../../../../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*, tv'_lst : typevar*, tu'_lst : typeuse*, var_1 : (typevar*, typeuse*)?, var_0_lst : subtype*}: + `%%%%`(REC_rectype(`%`_list(st_lst)), tv_lst, tu_lst, REC_rectype(`%`_list(var_0_lst))) + -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_1) + -- if (|var_0_lst| = |st_lst|) + -- (fun_subst_subtype: `%%%%`(st, tv'_lst, tu'_lst, var_0))*{var_0 <- var_0_lst, st <- st_lst} -- (wf_typevar: `%`(tv'#4))*{tv'#4 <- tv'_lst} -- (wf_typeuse: `%`(tu'#6))*{tu'#6 <- tu'_lst} - -- if ((tv'_lst, tu'_lst) = !($minus_recs(tv_lst, tu_lst))) - -;; ../../../../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) + -- if (var_1 =/= ?()) + -- if ((tv'_lst, tu'_lst) = !(var_1)) + +;; ../../../../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 @@ -1901,385 +2467,657 @@ 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 - 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_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 -def $subst_globaltype(v_globaltype : globaltype, var_0 : typevar*, var_1 : typeuse*) : globaltype +relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, 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 fun_subst_globaltype_case_0{mut_opt : mut?, t : valtype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : valtype, var_0 : valtype}: + `%%%%`(`%%`_globaltype(mut_opt, t), tv_lst, tu_lst, `%%`_globaltype(mut_opt, var_0)) + -- fun_subst_valtype: `%%%%`(t, tv_lst, tu_lst, var_1) + -- fun_subst_valtype: `%%%%`(t, tv_lst, tu_lst, var_0) + -- wf_globaltype: `%`(`%%`_globaltype(mut_opt, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_memtype(v_memtype : memtype, var_0 : typevar*, var_1 : typeuse*) : memtype +relation fun_subst_memtype: `%%%%`(memtype, typevar*, 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) + rule fun_subst_memtype_case_0{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 fun_subst_tabletype: `%%%%`(tabletype, typevar*, typeuse*, tabletype) ;; ../../../../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_tabletype_case_0{at : addrtype, lim : limits, rt : reftype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : reftype, var_0 : reftype}: + `%%%%`(`%%%`_tabletype(at, lim, rt), tv_lst, tu_lst, `%%%`_tabletype(at, lim, var_0)) + -- fun_subst_reftype: `%%%%`(rt, tv_lst, tu_lst, var_1) + -- fun_subst_reftype: `%%%%`(rt, tv_lst, tu_lst, var_0) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_externtype(v_externtype : externtype, var_0 : typevar*, var_1 : typeuse*) : externtype +relation fun_subst_externtype: `%%%%`(externtype, typevar*, typeuse*, externtype) ;; ../../../../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 fun_subst_externtype_case_0{jt : typeuse, tv_lst : typevar*, tu_lst : typeuse*, var_1 : tagtype, var_0 : tagtype}: + `%%%%`(TAG_externtype(jt), tv_lst, tu_lst, TAG_externtype(var_0)) + -- fun_subst_tagtype: `%%%%`(jt, tv_lst, tu_lst, var_1) + -- fun_subst_tagtype: `%%%%`(jt, tv_lst, tu_lst, var_0) + -- wf_externtype: `%`(TAG_externtype(var_1)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{gt : globaltype, tv_lst : typevar*, tu_lst : typeuse*}(GLOBAL_externtype(gt), tv_lst, tu_lst) = GLOBAL_externtype($subst_globaltype(gt, tv_lst, tu_lst)) - -- wf_externtype: `%`(GLOBAL_externtype($subst_globaltype(gt, tv_lst, tu_lst))) + rule fun_subst_externtype_case_1{gt : globaltype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : globaltype, var_0 : globaltype}: + `%%%%`(GLOBAL_externtype(gt), tv_lst, tu_lst, GLOBAL_externtype(var_0)) + -- fun_subst_globaltype: `%%%%`(gt, tv_lst, tu_lst, var_1) + -- fun_subst_globaltype: `%%%%`(gt, tv_lst, tu_lst, var_0) + -- wf_externtype: `%`(GLOBAL_externtype(var_1)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tt : tabletype, tv_lst : typevar*, tu_lst : typeuse*}(TABLE_externtype(tt), tv_lst, tu_lst) = TABLE_externtype($subst_tabletype(tt, tv_lst, tu_lst)) - -- wf_externtype: `%`(TABLE_externtype($subst_tabletype(tt, tv_lst, tu_lst))) + rule fun_subst_externtype_case_2{tt : tabletype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : tabletype, var_0 : tabletype}: + `%%%%`(TABLE_externtype(tt), tv_lst, tu_lst, TABLE_externtype(var_0)) + -- fun_subst_tabletype: `%%%%`(tt, tv_lst, tu_lst, var_1) + -- fun_subst_tabletype: `%%%%`(tt, tv_lst, tu_lst, var_0) + -- wf_externtype: `%`(TABLE_externtype(var_1)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{mt : memtype, tv_lst : typevar*, tu_lst : typeuse*}(MEM_externtype(mt), tv_lst, tu_lst) = MEM_externtype($subst_memtype(mt, tv_lst, tu_lst)) - -- wf_externtype: `%`(MEM_externtype($subst_memtype(mt, tv_lst, tu_lst))) + rule fun_subst_externtype_case_3{mt : memtype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : memtype, var_0 : memtype}: + `%%%%`(MEM_externtype(mt), tv_lst, tu_lst, MEM_externtype(var_0)) + -- fun_subst_memtype: `%%%%`(mt, tv_lst, tu_lst, var_1) + -- fun_subst_memtype: `%%%%`(mt, tv_lst, tu_lst, var_0) + -- wf_externtype: `%`(MEM_externtype(var_1)) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_externtype{tu' : typeuse, tv_lst : typevar*, tu_lst : typeuse*}(FUNC_externtype(tu'), tv_lst, tu_lst) = FUNC_externtype($subst_typeuse(tu', tv_lst, tu_lst)) - -- wf_externtype: `%`(FUNC_externtype($subst_typeuse(tu', tv_lst, tu_lst))) + rule fun_subst_externtype_case_4{tu' : typeuse, tv_lst : typevar*, tu_lst : typeuse*, var_1 : typeuse, var_0 : typeuse}: + `%%%%`(FUNC_externtype(tu'), tv_lst, tu_lst, FUNC_externtype(var_0)) + -- fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_1) + -- fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_0) + -- wf_externtype: `%`(FUNC_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_moduletype(v_moduletype : moduletype, var_0 : typevar*, var_1 : typeuse*) : moduletype +relation fun_subst_moduletype: `%%%%`(moduletype, typevar*, typeuse*, moduletype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_moduletype{xt_1_lst : externtype*, xt_2_lst : externtype*, tv_lst : typevar*, tu_lst : typeuse*}(`%->%`_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_moduletype_case_0{xt_1_lst : externtype*, xt_2_lst : externtype*, tv_lst : typevar*, tu_lst : typeuse*, var_3_lst : externtype*, var_2_lst : externtype*, var_1_lst : externtype*, var_0_lst : externtype*}: + `%%%%`(`%->%`_moduletype(xt_1_lst, xt_2_lst), tv_lst, tu_lst, `%->%`_moduletype(var_0_lst, var_1_lst)) + -- if (|var_3_lst| = |xt_2_lst|) + -- (fun_subst_externtype: `%%%%`(xt_2#2, tv_lst, tu_lst, var_3))*{var_3 <- var_3_lst, xt_2#2 <- xt_2_lst} + -- if (|var_2_lst| = |xt_1_lst|) + -- (fun_subst_externtype: `%%%%`(xt_1#2, tv_lst, tu_lst, var_2))*{var_2 <- var_2_lst, xt_1#2 <- xt_1_lst} + -- if (|var_1_lst| = |xt_2_lst|) + -- (fun_subst_externtype: `%%%%`(xt_2, tv_lst, tu_lst, var_1))*{var_1 <- var_1_lst, xt_2 <- xt_2_lst} + -- if (|var_0_lst| = |xt_1_lst|) + -- (fun_subst_externtype: `%%%%`(xt_1, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, xt_1 <- xt_1_lst} + -- wf_moduletype: `%`(`%->%`_moduletype(var_2_lst, var_3_lst)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $subst_all_valtype(v_valtype : valtype, var_0 : typeuse*) : valtype +relation fun_subst_all_valtype: `%%%`(valtype, typeuse*, valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $subst_all_valtype{t : valtype, v_n : nat, tu_lst : typeuse*, i : nat}(t, tu_lst) = $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(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: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}: + `%%`(`%`_resulttype(valtype_lst), var_0) + -- if (|var_1_lst| = |valtype_lst|) + -- (fun_free_valtype: `%%`(v_valtype, var_1))*{var_1 <- var_1_lst, v_valtype <- 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{var_0 : free}: + `%%`(I8_storagetype, var_0) + -- fun_free_packtype: `%%`(I8_packtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:488.6-488.23 + rule fun_free_storagetype_case_8{var_0 : free}: + `%%`(I16_storagetype, var_0) + -- fun_free_packtype: `%%`(I16_packtype, var_0) + +;; ../../../../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}: + `%%`(`%%`_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(`%`_list(fieldtype_lst)), var_0) + -- if (|var_1_lst| = |fieldtype_lst|) + -- (fun_free_fieldtype: `%%`(v_fieldtype, var_1))*{var_1 <- var_1_lst, v_fieldtype <- 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) + -- if (|var_1_lst| = |typeuse_lst|) + -- (fun_free_typeuse: `%%`(v_typeuse, var_1))*{var_1 <- var_1_lst, v_typeuse <- 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(`%`_list(subtype_lst)), var_0) + -- if (|var_1_lst| = |subtype_lst|) + -- (fun_free_subtype: `%%`(v_subtype, var_1))*{var_1 <- var_1_lst, v_subtype <- 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 +relation fun_free_tagtype: `%%`(tagtype, 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_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 -def $free_globaltype(v_globaltype : globaltype) : free +relation fun_free_globaltype: `%%`(globaltype, 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 fun_free_globaltype_case_0{mut_opt : mut?, v_valtype : valtype, var_0 : free}: + `%%`(`%%`_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_memtype(v_memtype : memtype) : free +relation fun_free_memtype: `%%`(memtype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_memtype{v_addrtype : addrtype, v_limits : limits}(`%%PAGE`_memtype(v_addrtype, v_limits)) = $free_addrtype(v_addrtype) + rule fun_free_memtype_case_0{v_addrtype : addrtype, v_limits : limits, var_0 : free}: + `%%`(`%%PAGE`_memtype(v_addrtype, v_limits), var_0) + -- fun_free_addrtype: `%%`(v_addrtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_tabletype(v_tabletype : tabletype) : free +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_1 : free, var_0 : free}: + `%%`(`%%%`_tabletype(v_addrtype, v_limits, v_reftype), var_0 +++ var_1) + -- fun_free_reftype: `%%`(v_reftype, var_1) + -- fun_free_addrtype: `%%`(v_addrtype, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -def $free_datatype(v_datatype : datatype) : free +relation fun_free_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 []} + rule fun_free_datatype_case_0: + `%%`(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 fun_free_elemtype: `%%`(elemtype, free) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_elemtype{v_reftype : reftype}(v_reftype) = $free_reftype(v_reftype) + 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 -def $free_externtype(v_externtype : externtype) : free +relation fun_free_externtype: `%%`(externtype, free) ;; ../../../../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_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_globaltype : globaltype}(GLOBAL_externtype(v_globaltype)) = $free_globaltype(v_globaltype) + 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 - def $free_externtype{v_memtype : memtype}(MEM_externtype(v_memtype)) = $free_memtype(v_memtype) + rule fun_free_externtype_case_2{v_memtype : memtype, var_0 : free}: + `%%`(MEM_externtype(v_memtype), var_0) + -- fun_free_memtype: `%%`(v_memtype, var_0) + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - def $free_externtype{v_tabletype : tabletype}(TABLE_externtype(v_tabletype)) = $free_tabletype(v_tabletype) + 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_typeuse : typeuse}(FUNC_externtype(v_typeuse)) = $free_typeuse(v_typeuse) + 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 -def $free_moduletype(v_moduletype : moduletype) : free +relation fun_free_moduletype: `%%`(moduletype, 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 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}: + `%%`(`%->%`_moduletype(externtype_1_lst, externtype_2_lst), var_0 +++ var_2) + -- if (|var_3_lst| = |externtype_2_lst|) + -- (fun_free_externtype: `%%`(externtype_2, var_3))*{var_3 <- var_3_lst, externtype_2 <- externtype_2_lst} + -- fun_free_list: `%%`(var_3_lst, var_2) + -- if (|var_1_lst| = |externtype_1_lst|) + -- (fun_free_externtype: `%%`(externtype_1, var_1))*{var_1 <- var_1_lst, externtype_1 <- externtype_1_lst} + -- fun_free_list: `%%`(var_1_lst, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec syntax num_ = @@ -2794,9 +3632,10 @@ relation wf_shape: `%`(shape) -- if (($lsize(v_lanetype) * $proj_dim_0(v_dim).0) = 128) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $fun_dim(v_shape : shape) : dim +relation fun_dim: `%%`(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) + rule fun_dim_case_0{v_Lnn : lanetype, v_N : nat}: + `%%`(`%X%`_shape(v_Lnn, `%`_dim(v_N)), `%`_dim(v_N)) -- wf_dim: `%`(`%`_dim(v_N)) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -4460,11 +5299,12 @@ relation wf_instr: `%`(instr) -- wf_vswizzlop_: `%%`(v_bshape, var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec:133.8-133.13 - rule instr_case_95{v_bshape : bshape, laneidx_lst : laneidx*}: + rule instr_case_95{v_bshape : bshape, laneidx_lst : laneidx*, var_0 : dim}: `%`(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 (`%`_dim(|laneidx_lst|) = var_0) + -- fun_dim: `%%`($proj_bshape_0(v_bshape).0, var_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__}: @@ -4581,305 +5421,696 @@ relation wf_instr: `%`(instr) syntax expr = instr* ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $memarg0 : memarg +relation fun_memarg0: `%`(memarg) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $memarg0 = {ALIGN `%`_u32(0), OFFSET `%`_u64(0)} + rule fun_memarg0_case_0: + `%`({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(v_consttype : consttype, v_lit_ : lit_) : instr +relation fun_const: `%%%`(consttype, 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) + rule fun_const_case_0{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) + rule fun_const_case_1{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) + rule fun_const_case_2{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) + rule fun_const_case_3{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) + rule fun_const_case_4{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 -def $free_shape(v_shape : shape) : free +relation fun_free_shape: `%%`(shape, free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_shape{v_lanetype : lanetype, v_dim : dim}(`%X%`_shape(v_lanetype, v_dim)) = $free_lanetype(v_lanetype) + rule fun_free_shape_case_0{v_lanetype : lanetype, v_dim : dim, var_0 : free}: + `%%`(`%X%`_shape(v_lanetype, v_dim), var_0) + -- fun_free_lanetype: `%%`(v_lanetype, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_blocktype(v_blocktype : blocktype) : free +relation fun_free_blocktype: `%%`(blocktype, free) ;; ../../../../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_0{valtype_opt : valtype?, var_1_opt : free?, var_0 : free}: + `%%`(_RESULT_blocktype(valtype_opt), var_0) + -- if ((var_1_opt = ?()) <=> (valtype_opt = ?())) + -- (fun_free_valtype: `%%`(v_valtype, var_1))?{var_1 <- var_1_opt, v_valtype <- valtype_opt} + -- fun_free_opt: `%%`(var_1_opt, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_blocktype{v_typeidx : uN}(_IDX_blocktype(v_typeidx)) = $free_typeidx(v_typeidx) + rule fun_free_blocktype_case_1{v_typeidx : uN, var_0 : free}: + `%%`(_IDX_blocktype(v_typeidx), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec -def $free_catch(v_catch : catch) : free +relation fun_free_catch: `%%`(catch, free) ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{v_tagidx : uN, v_labelidx : uN}(CATCH_catch(v_tagidx, v_labelidx)) = $free_tagidx(v_tagidx) +++ $free_labelidx(v_labelidx) + rule fun_free_catch_case_0{v_tagidx : uN, v_labelidx : uN, var_1 : free, var_0 : free}: + `%%`(CATCH_catch(v_tagidx, v_labelidx), var_0 +++ var_1) + -- fun_free_labelidx: `%%`(v_labelidx, var_1) + -- fun_free_tagidx: `%%`(v_tagidx, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{v_tagidx : uN, v_labelidx : uN}(CATCH_REF_catch(v_tagidx, v_labelidx)) = $free_tagidx(v_tagidx) +++ $free_labelidx(v_labelidx) + rule fun_free_catch_case_1{v_tagidx : uN, v_labelidx : uN, var_1 : free, var_0 : free}: + `%%`(CATCH_REF_catch(v_tagidx, v_labelidx), var_0 +++ var_1) + -- fun_free_labelidx: `%%`(v_labelidx, var_1) + -- fun_free_tagidx: `%%`(v_tagidx, var_0) + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec - def $free_catch{v_labelidx : uN}(CATCH_ALL_catch(v_labelidx)) = $free_labelidx(v_labelidx) + rule fun_free_catch_case_2{v_labelidx : uN, var_0 : free}: + `%%`(CATCH_ALL_catch(v_labelidx), var_0) + -- fun_free_labelidx: `%%`(v_labelidx, var_0) + ;; ../../../../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) + rule fun_free_catch_case_3{v_labelidx : uN, var_0 : free}: + `%%`(CATCH_ALL_REF_catch(v_labelidx), var_0) + -- fun_free_labelidx: `%%`(v_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(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) +;; ../../../../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*}: + `%%`([`%`_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, [`%`_labelidx(((($proj_uN_0(v_labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) + -- fun_shift_labelidxs: `%%`(labelidx'_lst, var_0) -- 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 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 []} +;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_3{valtype_lst_opt : valtype*?, var_2_lst_opt : free*?, var_1_opt : free?, var_0 : free}: + `%%`(SELECT_instr(valtype_lst_opt), var_0) + -- if ((var_2_lst_opt = ?()) <=> (valtype_lst_opt = ?())) + -- (if (|var_2_lst| = |valtype_lst|))?{var_2_lst <- var_2_lst_opt, valtype_lst <- valtype_lst_opt} + -- (fun_free_valtype: `%%`(v_valtype, var_2))*{var_2 <- var_2_lst, v_valtype <- valtype_lst}?{var_2_lst <- var_2_lst_opt, valtype_lst <- valtype_lst_opt} + -- if ((var_2_lst_opt = ?()) <=> (var_1_opt = ?())) + -- (fun_free_list: `%%`(var_2_lst, var_1))?{var_2_lst <- var_2_lst_opt, var_1 <- var_1_opt} + -- fun_free_opt: `%%`(var_1_opt, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(BR_instr(v_labelidx), var_0) + -- fun_free_labelidx: `%%`(v_labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_8{v_labelidx : uN, var_0 : free}: + `%%`(BR_IF_instr(v_labelidx), var_0) + -- fun_free_labelidx: `%%`(v_labelidx, var_0) + + ;; ../../../../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_2 : free, var_1_lst : free*, var_0 : free}: + `%%`(BR_TABLE_instr(labelidx_lst, labelidx'), var_0 +++ var_2) + -- fun_free_labelidx: `%%`(labelidx', var_2) + -- if (|var_1_lst| = |labelidx_lst|) + -- (fun_free_labelidx: `%%`(v_labelidx, var_1))*{var_1 <- var_1_lst, v_labelidx <- labelidx_lst} + -- fun_free_list: `%%`(var_1_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, var_0 : free}: + `%%`(BR_ON_NULL_instr(v_labelidx), var_0) + -- fun_free_labelidx: `%%`(v_labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_11{v_labelidx : uN, var_0 : free}: + `%%`(BR_ON_NON_NULL_instr(v_labelidx), var_0) + -- fun_free_labelidx: `%%`(v_labelidx, var_0) + + ;; ../../../../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_2 : free, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_instr(v_labelidx, reftype_1, reftype_2), var_0 +++ var_1 +++ var_2) + -- fun_free_reftype: `%%`(reftype_2, var_2) + -- fun_free_reftype: `%%`(reftype_1, var_1) + -- fun_free_labelidx: `%%`(v_labelidx, 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_2 : free, var_1 : free, var_0 : free}: + `%%`(BR_ON_CAST_FAIL_instr(v_labelidx, reftype_1, reftype_2), var_0 +++ var_1 +++ var_2) + -- fun_free_reftype: `%%`(reftype_2, var_2) + -- fun_free_reftype: `%%`(reftype_1, var_1) + -- fun_free_labelidx: `%%`(v_labelidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_14{v_funcidx : uN, var_0 : free}: + `%%`(CALL_instr(v_funcidx), var_0) + -- fun_free_funcidx: `%%`(v_funcidx, var_0) + + ;; ../../../../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_1 : free, var_0 : free}: + `%%`(CALL_INDIRECT_instr(v_tableidx, v_typeuse), var_0 +++ var_1) + -- fun_free_typeuse: `%%`(v_typeuse, var_1) + -- fun_free_tableidx: `%%`(v_tableidx, 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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_18{v_funcidx : uN, var_0 : free}: + `%%`(RETURN_CALL_instr(v_funcidx), var_0) + -- fun_free_funcidx: `%%`(v_funcidx, var_0) + + ;; ../../../../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_1 : free, var_0 : free}: + `%%`(RETURN_CALL_INDIRECT_instr(v_tableidx, v_typeuse), var_0 +++ var_1) + -- fun_free_typeuse: `%%`(v_typeuse, var_1) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_21{v_tagidx : uN, var_0 : free}: + `%%`(THROW_instr(v_tagidx), var_0) + -- fun_free_tagidx: `%%`(v_tagidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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_4_lst : free*, var_3 : free, var_2_lst : free*, var_1 : free, var_0 : free}: + `%%`(TRY_TABLE_instr(v_blocktype, `%`_list(catch_lst), instr_lst), var_0 +++ var_1 +++ var_3) + -- if (|var_4_lst| = |instr_lst|) + -- (fun_free_instr: `%%`(v_instr, var_4))*{var_4 <- var_4_lst, v_instr <- instr_lst} + -- fun_free_list: `%%`(var_4_lst, var_3) + -- if (|var_2_lst| = |catch_lst|) + -- (fun_free_catch: `%%`(v_catch, var_2))*{var_2 <- var_2_lst, v_catch <- catch_lst} + -- fun_free_list: `%%`(var_2_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_, var_0 : free}: + `%%`(CONST_instr(v_numtype, numlit), var_0) + -- fun_free_numtype: `%%`(v_numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_25{v_numtype : numtype, unop : unop_, var_0 : free}: + `%%`(UNOP_instr(v_numtype, unop), var_0) + -- fun_free_numtype: `%%`(v_numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_26{v_numtype : numtype, binop : binop_, var_0 : free}: + `%%`(BINOP_instr(v_numtype, binop), var_0) + -- fun_free_numtype: `%%`(v_numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_27{v_numtype : numtype, testop : testop_, var_0 : free}: + `%%`(TESTOP_instr(v_numtype, testop), var_0) + -- fun_free_numtype: `%%`(v_numtype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_28{v_numtype : numtype, relop : relop_, var_0 : free}: + `%%`(RELOP_instr(v_numtype, relop), var_0) + -- fun_free_numtype: `%%`(v_numtype, var_0) + + ;; ../../../../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__, var_1 : free, var_0 : free}: + `%%`(CVTOP_instr(numtype_1, numtype_2, cvtop), var_0 +++ var_1) + -- fun_free_numtype: `%%`(numtype_2, var_1) + -- fun_free_numtype: `%%`(numtype_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_30{v_vectype : vectype, veclit : uN, var_0 : free}: + `%%`(VCONST_instr(v_vectype, veclit), var_0) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VVUNOP_instr(v_vectype, v_vvunop), var_0) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VVBINOP_instr(v_vectype, v_vvbinop), var_0) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VVTERNOP_instr(v_vectype, v_vvternop), var_0) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VVTESTOP_instr(v_vectype, v_vvtestop), var_0) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_35{v_shape : shape, vunop : vunop_, var_0 : free}: + `%%`(VUNOP_instr(v_shape, vunop), var_0) + -- fun_free_shape: `%%`(v_shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_36{v_shape : shape, vbinop : vbinop_, var_0 : free}: + `%%`(VBINOP_instr(v_shape, vbinop), var_0) + -- fun_free_shape: `%%`(v_shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_37{v_shape : shape, vternop : vternop_, var_0 : free}: + `%%`(VTERNOP_instr(v_shape, vternop), var_0) + -- fun_free_shape: `%%`(v_shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_38{v_shape : shape, vtestop : vtestop_, var_0 : free}: + `%%`(VTESTOP_instr(v_shape, vtestop), var_0) + -- fun_free_shape: `%%`(v_shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_39{v_shape : shape, vrelop : vrelop_, var_0 : free}: + `%%`(VRELOP_instr(v_shape, vrelop), var_0) + -- fun_free_shape: `%%`(v_shape, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_40{v_ishape : ishape, vshiftop : vshiftop_, var_0 : free}: + `%%`(VSHIFTOP_instr(v_ishape, vshiftop), var_0) + -- fun_free_shape: `%%`($proj_ishape_0(v_ishape).0, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_41{v_ishape : ishape, var_0 : free}: + `%%`(VBITMASK_instr(v_ishape), var_0) + -- fun_free_shape: `%%`($proj_ishape_0(v_ishape).0, var_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_, var_0 : free}: + `%%`(VSWIZZLOP_instr(v_bshape, vswizzlop), var_0) + -- fun_free_shape: `%%`($proj_bshape_0(v_bshape).0, var_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*, var_0 : free}: + `%%`(VSHUFFLE_instr(v_bshape, laneidx_lst), var_0) + -- fun_free_shape: `%%`($proj_bshape_0(v_bshape).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTUNOP_instr(ishape_1, ishape_2, vextunop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTBINOP_instr(ishape_1, ishape_2, vextbinop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VEXTTERNOP_instr(ishape_1, ishape_2, vextternop), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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, var_1 : free, var_0 : free}: + `%%`(VNARROW_instr(ishape_1, ishape_2, v_sx), var_0 +++ var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_2).0, var_1) + -- fun_free_shape: `%%`($proj_ishape_0(ishape_1).0, var_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__, var_1 : free, var_0 : free}: + `%%`(VCVTOP_instr(shape_1, shape_2, vcvtop), var_0 +++ var_1) + -- fun_free_shape: `%%`(shape_2, var_1) + -- fun_free_shape: `%%`(shape_1, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_49{v_shape : shape, var_0 : free}: + `%%`(VSPLAT_instr(v_shape), var_0) + -- fun_free_shape: `%%`(v_shape, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VEXTRACT_LANE_instr(v_shape, sx_opt, v_laneidx), var_0) + -- fun_free_shape: `%%`(v_shape, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(VREPLACE_LANE_instr(v_shape, v_laneidx), var_0) + -- fun_free_shape: `%%`(v_shape, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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, var_0 : free}: + `%%`(`REF.FUNC`_instr(v_funcidx), var_0) + -- fun_free_funcidx: `%%`(v_funcidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_61{v_typeidx : uN, var_0 : free}: + `%%`(`STRUCT.NEW`_instr(v_typeidx), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_62{v_typeidx : uN, var_0 : free}: + `%%`(`STRUCT.NEW_DEFAULT`_instr(v_typeidx), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(`STRUCT.GET`_instr(sx_opt, v_typeidx, v_u32), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(`STRUCT.SET`_instr(v_typeidx, v_u32), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_65{v_typeidx : uN, var_0 : free}: + `%%`(`ARRAY.NEW`_instr(v_typeidx), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_66{v_typeidx : uN, var_0 : free}: + `%%`(`ARRAY.NEW_DEFAULT`_instr(v_typeidx), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(`ARRAY.NEW_FIXED`_instr(v_typeidx, v_u32), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`ARRAY.NEW_DATA`_instr(v_typeidx, v_dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(v_dataidx, var_1) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`ARRAY.NEW_ELEM`_instr(v_typeidx, v_elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(v_elemidx, var_1) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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, var_0 : free}: + `%%`(`ARRAY.GET`_instr(sx_opt, v_typeidx), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_71{v_typeidx : uN, var_0 : free}: + `%%`(`ARRAY.SET`_instr(v_typeidx), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_73{v_typeidx : uN, var_0 : free}: + `%%`(`ARRAY.FILL`_instr(v_typeidx), var_0) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`ARRAY.COPY`_instr(typeidx_1, typeidx_2), var_0 +++ var_1) + -- fun_free_typeidx: `%%`(typeidx_2, var_1) + -- fun_free_typeidx: `%%`(typeidx_1, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`ARRAY.INIT_DATA`_instr(v_typeidx, v_dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(v_dataidx, var_1) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`ARRAY.INIT_ELEM`_instr(v_typeidx, v_elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(v_elemidx, var_1) + -- fun_free_typeidx: `%%`(v_typeidx, var_0) + + ;; ../../../../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 []}) -- 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 []} + + ;; ../../../../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 []}) -- 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*, v_free : free}(instr_lst) = v_free[LABELS_free = $shift_labelidxs(v_free.LABELS_free)] + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_79{v_localidx : uN, var_0 : free}: + `%%`(`LOCAL.GET`_instr(v_localidx), var_0) + -- fun_free_localidx: `%%`(v_localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_80{v_localidx : uN, var_0 : free}: + `%%`(`LOCAL.SET`_instr(v_localidx), var_0) + -- fun_free_localidx: `%%`(v_localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_81{v_localidx : uN, var_0 : free}: + `%%`(`LOCAL.TEE`_instr(v_localidx), var_0) + -- fun_free_localidx: `%%`(v_localidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_82{v_globalidx : uN, var_0 : free}: + `%%`(`GLOBAL.GET`_instr(v_globalidx), var_0) + -- fun_free_globalidx: `%%`(v_globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_83{v_globalidx : uN, var_0 : free}: + `%%`(`GLOBAL.SET`_instr(v_globalidx), var_0) + -- fun_free_globalidx: `%%`(v_globalidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_84{v_tableidx : uN, var_0 : free}: + `%%`(`TABLE.GET`_instr(v_tableidx), var_0) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_85{v_tableidx : uN, var_0 : free}: + `%%`(`TABLE.SET`_instr(v_tableidx), var_0) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_86{v_tableidx : uN, var_0 : free}: + `%%`(`TABLE.SIZE`_instr(v_tableidx), var_0) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_87{v_tableidx : uN, var_0 : free}: + `%%`(`TABLE.GROW`_instr(v_tableidx), var_0) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_88{v_tableidx : uN, var_0 : free}: + `%%`(`TABLE.FILL`_instr(v_tableidx), var_0) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`TABLE.COPY`_instr(tableidx_1, tableidx_2), var_0 +++ var_1) + -- fun_free_tableidx: `%%`(tableidx_2, var_1) + -- fun_free_tableidx: `%%`(tableidx_1, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`TABLE.INIT`_instr(v_tableidx, v_elemidx), var_0 +++ var_1) + -- fun_free_elemidx: `%%`(v_elemidx, var_1) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_91{v_elemidx : uN, var_0 : free}: + `%%`(`ELEM.DROP`_instr(v_elemidx), var_0) + -- fun_free_elemidx: `%%`(v_elemidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(LOAD_instr(v_numtype, loadop_opt, v_memidx, v_memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(v_memidx, var_1) + -- fun_free_numtype: `%%`(v_numtype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(STORE_instr(v_numtype, storeop_opt, v_memidx, v_memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(v_memidx, var_1) + -- fun_free_numtype: `%%`(v_numtype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VLOAD_instr(v_vectype, vloadop_opt, v_memidx, v_memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(v_memidx, var_1) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VLOAD_LANE_instr(v_vectype, v_sz, v_memidx, v_memarg, v_laneidx), var_0 +++ var_1) + -- fun_free_memidx: `%%`(v_memidx, var_1) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VSTORE_instr(v_vectype, v_memidx, v_memarg), var_0 +++ var_1) + -- fun_free_memidx: `%%`(v_memidx, var_1) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(VSTORE_LANE_instr(v_vectype, v_sz, v_memidx, v_memarg, v_laneidx), var_0 +++ var_1) + -- fun_free_memidx: `%%`(v_memidx, var_1) + -- fun_free_vectype: `%%`(v_vectype, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_98{v_memidx : uN, var_0 : free}: + `%%`(`MEMORY.SIZE`_instr(v_memidx), var_0) + -- fun_free_memidx: `%%`(v_memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_99{v_memidx : uN, var_0 : free}: + `%%`(`MEMORY.GROW`_instr(v_memidx), var_0) + -- fun_free_memidx: `%%`(v_memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_100{v_memidx : uN, var_0 : free}: + `%%`(`MEMORY.FILL`_instr(v_memidx), var_0) + -- fun_free_memidx: `%%`(v_memidx, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`MEMORY.COPY`_instr(memidx_1, memidx_2), var_0 +++ var_1) + -- fun_free_memidx: `%%`(memidx_2, var_1) + -- fun_free_memidx: `%%`(memidx_1, var_0) + + ;; ../../../../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, var_1 : free, var_0 : free}: + `%%`(`MEMORY.INIT`_instr(v_memidx, v_dataidx), var_0 +++ var_1) + -- fun_free_dataidx: `%%`(v_dataidx, var_1) + -- fun_free_memidx: `%%`(v_memidx, var_0) + + ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec:420.6-420.17 + rule fun_free_instr_case_103{v_dataidx : uN, var_0 : free}: + `%%`(`DATA.DROP`_instr(v_dataidx), var_0) + -- fun_free_dataidx: `%%`(v_dataidx, var_0) + +;; ../../../../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*, v_free : free, var_2_lst : free*, var_1 : free, var_0 : labelidx*}: + `%%`(instr_lst, v_free[LABELS_free = var_0]) + -- if (|var_2_lst| = |instr_lst|) + -- (fun_free_instr: `%%`(instr#5, var_2))*{var_2 <- var_2_lst, instr#5 <- instr_lst} + -- fun_free_list: `%%`(var_2_lst, var_1) + -- fun_shift_labelidxs: `%%`(v_free.LABELS_free, var_0) -- wf_free: `%`(v_free) - -- if (v_free = $free_list($free_instr(instr#5)*{instr#5 <- instr_lst})) + -- if (v_free = 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 - def $free_expr{instr_lst : instr*}(instr_lst) = $free_list($free_instr(v_instr)*{v_instr <- instr_lst}) + rule fun_free_expr_case_0{instr_lst : instr*, var_1_lst : free*, var_0 : free}: + `%%`(instr_lst, var_0) + -- if (|var_1_lst| = |instr_lst|) + -- (fun_free_instr: `%%`(v_instr, var_1))*{var_1 <- var_1_lst, v_instr <- instr_lst} + -- fun_free_list: `%%`(var_1_lst, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec syntax elemmode = @@ -5067,98 +6298,184 @@ 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 - def $free_type{v_rectype : rectype}(TYPE_type(v_rectype)) = $free_rectype(v_rectype) + 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 -def $free_tag(v_tag : tag) : free +relation fun_free_tag: `%%`(tag, 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_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 -def $free_global(v_global : global) : free +relation fun_free_global: `%%`(global, 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 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_mem(v_mem : mem) : free +relation fun_free_mem: `%%`(mem, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_mem{v_memtype : memtype}(MEMORY_mem(v_memtype)) = $free_memtype(v_memtype) + rule fun_free_mem_case_0{v_memtype : memtype, var_0 : free}: + `%%`(MEMORY_mem(v_memtype), var_0) + -- fun_free_memtype: `%%`(v_memtype, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_table(v_table : table) : free +relation fun_free_table: `%%`(table, 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 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 -def $free_local(v_local : local) : free +relation fun_free_local: `%%`(local, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_local{t : valtype}(LOCAL_local(t)) = $free_valtype(t) + 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_func(v_func : func) : free +relation fun_free_func: `%%`(func, 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 fun_free_func_case_0{v_typeidx : uN, local_lst : local*, v_expr : instr*, var_3 : free, var_2_lst : free*, var_1 : free, var_0 : free}: + `%%`(FUNC_func(v_typeidx, local_lst, v_expr), var_0 +++ var_1 +++ var_3[LOCALS_free = []]) + -- fun_free_block: `%%`(v_expr, var_3) + -- if (|var_2_lst| = |local_lst|) + -- (fun_free_local: `%%`(v_local, var_2))*{var_2 <- var_2_lst, v_local <- local_lst} + -- fun_free_list: `%%`(var_2_lst, var_1) + -- fun_free_typeidx: `%%`(v_typeidx, 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_1 : free, var_0 : free}: + `%%`(ACTIVE_datamode(v_memidx, v_expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(v_expr, var_1) + -- fun_free_memidx: `%%`(v_memidx, var_0) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_datamode(PASSIVE_datamode) = {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 []}) -- wf_free: `%`({TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []}) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_data(v_data : data) : free +relation fun_free_data: `%%`(data, 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 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_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_1 : free, var_0 : free}: + `%%`(ACTIVE_elemmode(v_tableidx, v_expr), var_0 +++ var_1) + -- fun_free_expr: `%%`(v_expr, var_1) + -- fun_free_tableidx: `%%`(v_tableidx, var_0) + ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_elemmode(PASSIVE_elemmode) = {TYPES [], FUNCS [], GLOBALS [], TABLES [], MEMS [], ELEMS [], DATAS [], LOCALS [], LABELS [], TAGS []} + rule fun_free_elemmode_case_1: + `%%`(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 []} + rule fun_free_elemmode_case_2: + `%%`(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(v_elem : elem) : free +relation fun_free_elem: `%%`(elem, 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 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) + -- if (|var_2_lst| = |expr_lst|) + -- (fun_free_expr: `%%`(v_expr, var_2))*{var_2 <- var_2_lst, v_expr <- 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_start(v_start : start) : free +relation fun_free_start: `%%`(start, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_start{v_funcidx : uN}(START_start(v_funcidx)) = $free_funcidx(v_funcidx) + rule fun_free_start_case_0{v_funcidx : uN, var_0 : free}: + `%%`(START_start(v_funcidx), var_0) + -- fun_free_funcidx: `%%`(v_funcidx, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_import(v_import : import) : free +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 -def $free_export(v_export : export) : free +relation fun_free_export: `%%`(export, free) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec - def $free_export{v_name : name, v_externidx : externidx}(EXPORT_export(v_name, v_externidx)) = $free_externidx(v_externidx) + rule fun_free_export_case_0{v_name : name, v_externidx : externidx, var_0 : free}: + `%%`(EXPORT_export(v_name, v_externidx), var_0) + -- fun_free_externidx: `%%`(v_externidx, var_0) ;; ../../../../specification/wasm-3.0/1.4-syntax.modules.spectec -def $free_module(v_module : module) : free +relation fun_free_module: `%%`(module, 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 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_21_lst : free*, var_20 : free, var_19_lst : free*, var_18 : free, var_17_opt : free?, var_16 : free, var_15_lst : free*, var_14 : free, var_13_lst : free*, var_12 : free, var_11_lst : free*, var_10 : free, var_9_lst : free*, var_8 : free, var_7_lst : 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(`%`_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)), var_0 +++ var_2 +++ var_4 +++ var_6 +++ var_8 +++ var_10 +++ var_12 +++ var_14 +++ var_16 +++ var_18 +++ var_20) + -- if (|var_21_lst| = |export_lst|) + -- (fun_free_export: `%%`(v_export, var_21))*{var_21 <- var_21_lst, v_export <- export_lst} + -- fun_free_list: `%%`(var_21_lst, var_20) + -- if (|var_19_lst| = |import_lst|) + -- (fun_free_import: `%%`(v_import, var_19))*{var_19 <- var_19_lst, v_import <- import_lst} + -- fun_free_list: `%%`(var_19_lst, var_18) + -- if ((var_17_opt = ?()) <=> (start_opt = ?())) + -- (fun_free_start: `%%`(v_start, var_17))?{var_17 <- var_17_opt, v_start <- start_opt} + -- fun_free_opt: `%%`(var_17_opt, var_16) + -- if (|var_15_lst| = |elem_lst|) + -- (fun_free_elem: `%%`(v_elem, var_15))*{var_15 <- var_15_lst, v_elem <- elem_lst} + -- fun_free_list: `%%`(var_15_lst, var_14) + -- if (|var_13_lst| = |data_lst|) + -- (fun_free_data: `%%`(v_data, var_13))*{var_13 <- var_13_lst, v_data <- data_lst} + -- fun_free_list: `%%`(var_13_lst, var_12) + -- if (|var_11_lst| = |func_lst|) + -- (fun_free_func: `%%`(v_func, var_11))*{var_11 <- var_11_lst, v_func <- func_lst} + -- fun_free_list: `%%`(var_11_lst, var_10) + -- if (|var_9_lst| = |table_lst|) + -- (fun_free_table: `%%`(v_table, var_9))*{var_9 <- var_9_lst, v_table <- table_lst} + -- fun_free_list: `%%`(var_9_lst, var_8) + -- if (|var_7_lst| = |mem_lst|) + -- (fun_free_mem: `%%`(v_mem, var_7))*{var_7 <- var_7_lst, v_mem <- mem_lst} + -- fun_free_list: `%%`(var_7_lst, var_6) + -- if (|var_5_lst| = |global_lst|) + -- (fun_free_global: `%%`(v_global, var_5))*{var_5 <- var_5_lst, v_global <- global_lst} + -- fun_free_list: `%%`(var_5_lst, var_4) + -- if (|var_3_lst| = |tag_lst|) + -- (fun_free_tag: `%%`(v_tag, var_3))*{var_3 <- var_3_lst, v_tag <- tag_lst} + -- fun_free_list: `%%`(var_3_lst, var_2) + -- if (|var_1_lst| = |type_lst|) + -- (fun_free_type: `%%`(v_type, var_1))*{var_1 <- var_1_lst, v_type <- type_lst} + -- fun_free_list: `%%`(var_1_lst, 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) + -- if (|var_1_lst| = |func_lst|) + -- (fun_free_func: `%%`(v_func, var_1))*{var_1 <- var_1_lst, v_func <- func_lst} + -- fun_free_list: `%%`(var_1_lst, var_0) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec syntax init = @@ -5219,60 +6536,97 @@ 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: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 : deftype*}(dt_lst ++ [dt_n]) = dt'_lst ++ [$subst_all_deftype(dt_n, $typeuse_deftype(dt')*{dt' <- dt'_lst})] - -- if (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, dt'_lst : deftype*, var_1 : deftype*, var_0 : deftype}: + `%%`(dt_lst ++ [dt_n], dt'_lst ++ [var_0]) + -- fun_clos_deftypes: `%%`(dt_lst, var_1) + -- fun_subst_all_deftype: `%%%`(dt_n, $typeuse_deftype(dt')*{dt' <- dt'_lst}, var_0) + -- if (dt'_lst = var_1) } ;; ../../../../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 - def $clos_valtype{C : context, t : valtype, dt_lst : deftype*}(C, t) = $subst_all_valtype(t, $typeuse_deftype(dt)*{dt <- dt_lst}) - -- if (dt_lst = $clos_deftypes(C.TYPES_context)) + rule fun_clos_valtype_case_0{C : context, t : valtype, dt_lst : deftype*, var_1 : deftype*, var_0 : valtype}: + `%%%`(C, t, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_valtype: `%%%`(t, $typeuse_deftype(dt)*{dt <- dt_lst}, var_0) + -- if (dt_lst = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_deftype(v_context : context, v_deftype : deftype) : deftype +relation fun_clos_deftype: `%%%`(context, deftype, deftype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_deftype{C : context, dt : deftype, dt'_lst : deftype*}(C, dt) = $subst_all_deftype(dt, $typeuse_deftype(dt')*{dt' <- dt'_lst}) - -- if (dt'_lst = $clos_deftypes(C.TYPES_context)) + rule fun_clos_deftype_case_0{C : context, dt : deftype, dt'_lst : deftype*, var_1 : deftype*, var_0 : deftype}: + `%%%`(C, dt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_deftype: `%%%`(dt, $typeuse_deftype(dt')*{dt' <- dt'_lst}, var_0) + -- if (dt'_lst = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_tagtype(v_context : context, v_tagtype : tagtype) : tagtype +relation fun_clos_tagtype: `%%%`(context, tagtype, tagtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_tagtype{C : context, jt : typeuse, dt_lst : deftype*}(C, jt) = $subst_all_tagtype(jt, $typeuse_deftype(dt)*{dt <- dt_lst}) - -- if (dt_lst = $clos_deftypes(C.TYPES_context)) + rule fun_clos_tagtype_case_0{C : context, jt : typeuse, dt_lst : deftype*, var_1 : deftype*, var_0 : tagtype}: + `%%%`(C, jt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_tagtype: `%%%`(jt, $typeuse_deftype(dt)*{dt <- dt_lst}, var_0) + -- if (dt_lst = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_externtype(v_context : context, v_externtype : externtype) : externtype +relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_externtype{C : context, xt : externtype, dt_lst : deftype*}(C, xt) = $subst_all_externtype(xt, $typeuse_deftype(dt)*{dt <- dt_lst}) - -- if (dt_lst = $clos_deftypes(C.TYPES_context)) + rule fun_clos_externtype_case_0{C : context, xt : externtype, dt_lst : deftype*, var_1 : deftype*, var_0 : externtype}: + `%%%`(C, xt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_externtype: `%%%`(xt, $typeuse_deftype(dt)*{dt <- dt_lst}, var_0) + -- if (dt_lst = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec -def $clos_moduletype(v_context : context, v_moduletype : moduletype) : moduletype +relation fun_clos_moduletype: `%%%`(context, moduletype, moduletype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec - def $clos_moduletype{C : context, mmt : moduletype, dt_lst : deftype*}(C, mmt) = $subst_all_moduletype(mmt, $typeuse_deftype(dt)*{dt <- dt_lst}) - -- if (dt_lst = $clos_deftypes(C.TYPES_context)) + rule fun_clos_moduletype_case_0{C : context, mmt : moduletype, dt_lst : deftype*, var_1 : deftype*, var_0 : moduletype}: + `%%%`(C, mmt, var_0) + -- fun_clos_deftypes: `%%`(C.TYPES_context, var_1) + -- fun_subst_all_moduletype: `%%%`(mmt, $typeuse_deftype(dt)*{dt <- dt_lst}, var_0) + -- if (dt_lst = var_1) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -5316,10 +6670,11 @@ 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) -- wf_subtype: `%`(SUB_subtype(final_opt, typeuse_lst, 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)) + -- fun_unrolldt: `%%`(v_deftype, var_0) ;; ../../../../specification/wasm-3.0/2.2-validation.subtyping.spectec relation Vectype_sub: `%|-%<:%`(context, vectype, vectype) @@ -5336,13 +6691,22 @@ 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 - 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_1{C : context, v_typeidx : uN, var_0 : subtype}: + `%%%`(C, _IDX_heaptype(v_typeidx), var_0) + -- if ($proj_uN_0(v_typeidx).0 < |C.TYPES_context|) + -- fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(v_typeidx).0], var_0) + ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec - def $unrollht_{C : context, i : nat}(C, REC_heaptype(i)) = C.RECS_context[i] + 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 rec { @@ -5488,7 +6852,7 @@ 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 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)) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), typeuse_lst, v_comptype)) @@ -5497,10 +6861,13 @@ relation Subtype_ok2: `%|-%:%`(context, subtype, oktypenat) -- 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 ($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_lst| = |comptype'_lst|) + -- if (|var_0_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} -- Comptype_ok: `%|-%:OK`(C, v_comptype) -- (Comptype_sub: `%|-%<:%`(C, v_comptype, comptype'))*{comptype' <- comptype'_lst} + -- if (|var_0_lst| = |typeuse_lst|) + -- (fun_unrollht_: `%%%`(C, $heaptype_typeuse(v_typeuse), var_0))*{var_0 <- var_0_lst, v_typeuse <- typeuse_lst} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec:98.1-98.126 relation Rectype_ok2: `%|-%:%`(context, rectype, oktypenat) @@ -5560,19 +6927,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) -- wf_context: `%`(C) - -- if ($clos_deftype(C, deftype_1) = $clos_deftype(C, deftype_2)) + -- if (var_0 = var_1) + -- 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) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(final_opt, typeuse_lst, ct)) - -- if ($unrolldt(deftype_1) = SUB_subtype(final_opt, typeuse_lst, ct)) + -- if (var_0 = SUB_subtype(final_opt, typeuse_lst, ct)) -- if (i < |typeuse_lst|) -- Heaptype_sub: `%|-%<:%`(C, $heaptype_typeuse(typeuse_lst[i]), $heaptype_deftype(deftype_2)) + -- 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) @@ -5909,7 +7279,7 @@ 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)) -- wf_context: `%`(C) -- wf_subtype: `%`(SUB_subtype(?(FINAL_final), _IDX_typeuse(x)*{x <- x_lst}, v_comptype)) @@ -5918,11 +7288,14 @@ relation Subtype_ok: `%|-%:%`(context, subtype, oktypeidx) -- (wf_subtype: `%`(SUB_subtype(?(), yy_lst, comptype')))*{comptype' <- comptype'_lst, yy_lst <- yy_lst_lst} -- 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 ($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_lst| = |comptype'_lst|) + -- if (|var_0_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} -- Comptype_ok: `%|-%:OK`(C, v_comptype) -- (Comptype_sub: `%|-%<:%`(C, v_comptype, comptype'))*{comptype' <- comptype'_lst} + -- if (|var_0_lst| = |x_lst|) + -- (if ($proj_uN_0(x).0 < |C.TYPES_context|))*{x <- x_lst} + -- (fun_unrolldt: `%%`(C.TYPES_context[$proj_uN_0(x).0], var_0))*{var_0 <- var_0_lst, x <- x_lst} ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec rec { @@ -6186,28 +7559,30 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../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*}: + rule catch{C : context, x : idx, l : labelidx, t_lst : valtype*, var_0 : deftype?}: `%|-%:OK`(C, CATCH_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_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([]))) + -- if (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_0), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_lst), C.LABELS_context[$proj_uN_0(l).0]) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_ref{C : context, x : idx, l : labelidx, t_lst : valtype*}: + rule catch_ref{C : context, x : idx, l : labelidx, t_lst : valtype*, var_0 : deftype?}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_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([]))) + -- if (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_0), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) -- 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]) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: @@ -6226,38 +7601,95 @@ relation Catch_ok: `%|-%:OK`(context, catch) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype([REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec -def $default_(v_valtype : valtype) : val?? +relation fun_default__before_fun_default__case_7: `%`(valtype) ;; ../../../../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))))) + rule fun_default__case_6{ht : heaptype}: + `%`(REF_valtype(?(), ht)) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_5{ht : heaptype}: + `%`(REF_valtype(?(NULL_null), ht)) + -- wf_val: `%`(`REF.NULL_ADDR`_val) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_4: + `%`(V128_valtype) + -- wf_val: `%`(VCONST_val(V128_vectype, `%`_vec_(0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_3{var_0 : fN}: + `%`(F64_valtype) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_2{var_0 : fN}: + `%`(F32_valtype) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_1: + `%`(I64_valtype) + -- 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 + rule fun_default__case_0: + `%`(I32_valtype) + -- 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 +relation fun_default_: `%%`(valtype, val??) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_0: + `%%`(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))))) + rule fun_default__case_1: + `%%`(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)))))) + rule fun_default__case_2{var_0 : fN}: + `%%`(F32_valtype, ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + ;; ../../../../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)))))) + rule fun_default__case_3{var_0 : fN}: + `%%`(F64_valtype, ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec - def $default_(V128_valtype) = ?(?(VCONST_val(V128_vectype, `%`_vec_(0)))) + rule fun_default__case_4: + `%%`(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)) + rule fun_default__case_5{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 + rule fun_default__case_6{ht : heaptype}: + `%%`(REF_valtype(?(), ht), ?(?())) + + ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec + rule fun_default__case_7{x0 : valtype}: + `%%`(x0, ?()) + -- ~ fun_default__before_fun_default__case_7: `%`(x0) ;; ../../../../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}: + rule mk_Defaultable{t : valtype, var_0 : val??}: `|-%DEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) - -- if (!($default_(t)) =/= ?()) + -- if (var_0 =/= ?()) + -- if (!(var_0) =/= ?()) + -- fun_default_: `%%`(t, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) @@ -6269,9 +7701,11 @@ relation Memarg_ok: `|-%:%->%`(memarg, addrtype, N) -- if (v_m < (2 ^ $size($numtype_addrtype(at)))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec -def $is_packtype(v_storagetype : storagetype) : bool +relation fun_is_packtype: `%%`(storagetype, bool) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - def $is_packtype{zt : storagetype}(zt) = (zt =/= $storagetype_valtype($unpack(zt))) + rule fun_is_packtype_case_0{zt : storagetype, var_0 : valtype}: + `%%`(zt, (zt =/= $storagetype_valtype(var_0))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rec { @@ -6408,21 +7842,22 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- if (C.LABELS_context[$proj_uN_0(l).0] = `%`_resulttype(t_lst ++ [REF_valtype(?(NULL_null), ht)])) ;; ../../../../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))]))) + rule br_on_cast{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, t_lst : valtype*, rt : reftype, var_0 : reftype}: + `%|-%:%`(C, BR_ON_CAST_instr(l, rt_1, rt_2), `%->_%%`_instrtype(`%`_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t_lst ++ [$valtype_reftype(var_0)]))) -- 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: `%`(`%->_%%`_instrtype(`%`_resulttype(t_lst ++ [$valtype_reftype(rt_1)]), [], `%`_resulttype(t_lst ++ [$valtype_reftype(var_0)]))) -- 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, rt_2, rt) + -- fun_diffrt: `%%%`(rt_1, rt_2, var_0) ;; ../../../../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}: + rule br_on_cast_fail{C : context, l : labelidx, rt_1 : reftype, rt_2 : reftype, t_lst : valtype*, rt : reftype, var_0 : 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)]))) -- wf_context: `%`(C) -- wf_reftype: `%`(rt) @@ -6433,7 +7868,8 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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) + -- Reftype_sub: `%|-%<:%`(C, var_0, rt) + -- fun_diffrt: `%%%`(rt_1, rt_2, var_0) ;; ../../../../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*}: @@ -6531,17 +7967,18 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3_lst), [], `%`_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*}: + rule throw{C : context, x : idx, t_1_lst : valtype*, t_lst : valtype*, t_2_lst : valtype*, var_0 : deftype?}: `%|-%:%`(C, THROW_instr(x), `%->_%%`_instrtype(`%`_resulttype(t_1_lst ++ t_lst), [], `%`_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))) - -- 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([]))) + -- if (var_0 =/= ?()) + -- Expand: `%~~%`(!(var_0), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- if ($proj_uN_0(x).0 < |C.TAGS_context|) + -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../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*}: @@ -6641,17 +8078,19 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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_lst : storagetype*, mut_opt_lst : mut?*}: - `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype($unpack(zt)*{zt <- zt_lst}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + rule struct_new{C : context, x : idx, zt_lst : storagetype*, mut_opt_lst : mut?*, var_0_lst : valtype*}: + `%|-%:%`(C, `STRUCT.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype(var_0_lst), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(var_0_lst), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_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}))) + -- if (|var_0_lst| = |zt_lst|) + -- (fun_unpack: `%%`(zt, var_0))*{var_0 <- var_0_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*}: + rule struct_new_default{C : context, x : idx, mut_opt_lst : mut?*, zt_lst : storagetype*, var_0_lst : valtype*}: `%|-%:%`(C, `STRUCT.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`STRUCT.NEW_DEFAULT`_instr(x)) @@ -6659,47 +8098,53 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_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} + -- (Defaultable: `|-%DEFAULTABLE`(var_0))*{var_0 <- var_0_lst} + -- if (|var_0_lst| = |zt_lst|) + -- (fun_unpack: `%%`(zt, var_0))*{var_0 <- var_0_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)]))) + rule struct_get{C : context, sx_opt : sx?, x : idx, i : fieldidx, zt : storagetype, ft_lst : fieldtype*, mut_opt : mut?, var_1 : bool, var_0 : valtype}: + `%|-%:%`(C, `STRUCT.GET`_instr(sx_opt, x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([var_0]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x))]), [], `%`_resulttype([var_0]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_lst))) -- wf_fieldtype: `%`(`%%`_fieldtype(mut_opt, zt)) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft_lst))) -- 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)) + -- if ((sx_opt =/= ?()) <=> var_1) + -- fun_is_packtype: `%%`(zt, var_1) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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([]))) + rule struct_set{C : context, x : idx, i : fieldidx, zt : storagetype, ft_lst : fieldtype*, var_0 : valtype}: + `%|-%:%`(C, `STRUCT.SET`_instr(x, i), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) var_0]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) var_0]), [], `%`_resulttype([]))) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(ft_lst))) -- wf_fieldtype: `%`(`%%`_fieldtype(?(MUT_mut), zt)) -- if ($proj_uN_0(x).0 < |C.TYPES_context|) -- Expand: `%~~%`(C.TYPES_context[$proj_uN_0(x).0], STRUCT_comptype(`%`_list(ft_lst))) -- if ($proj_uN_0(i).0 < |ft_lst|) -- if (ft_lst[$proj_uN_0(i).0] = `%%`_fieldtype(?(MUT_mut), zt)) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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))]))) + rule array_new{C : context, x : idx, zt : storagetype, mut_opt : mut?, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW`_instr(x), `%->_%%`_instrtype(`%`_resulttype([var_0 I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW`_instr(x)) - -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([$unpack(zt) I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) + -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([var_0 I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: + rule array_new_default{C : context, x : idx, mut_opt : mut?, zt : storagetype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.NEW_DEFAULT`_instr(x), `%->_%%`_instrtype(`%`_resulttype([I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_DEFAULT`_instr(x)) @@ -6707,17 +8152,19 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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)) + -- Defaultable: `|-%DEFAULTABLE`(var_0) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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))]))) + rule array_new_fixed{C : context, x : idx, v_n : n, zt : storagetype, mut_opt : mut?, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n)), `%->_%%`_instrtype(`%`_resulttype(var_0^v_n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(var_0^v_n{}), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: @@ -6732,7 +8179,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Reftype_sub: `%|-%<:%`(C, C.ELEMS_context[$proj_uN_0(y).0], 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}: + rule array_new_data{C : context, x : idx, y : idx, mut_opt : mut?, zt : storagetype, v_numtype : numtype, v_vectype : vectype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.NEW_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([I32_valtype I32_valtype]), [], `%`_resulttype([REF_valtype(?(), _IDX_heaptype(x))]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.NEW_DATA`_instr(x, y)) @@ -6740,30 +8187,34 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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 ((var_0 = $valtype_numtype(v_numtype)) \/ (var_0 = $valtype_vectype(v_vectype))) -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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)]))) + rule array_get{C : context, sx_opt : sx?, x : idx, zt : storagetype, mut_opt : mut?, var_1 : bool, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.GET`_instr(sx_opt, x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([var_0]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype]), [], `%`_resulttype([var_0]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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)) + -- if ((sx_opt =/= ?()) <=> var_1) + -- fun_is_packtype: `%%`(zt, var_1) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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([]))) + rule array_set{C : context, x : idx, zt : storagetype, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.SET`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:305.1-306.43 rule array_len{C : context}: @@ -6773,14 +8224,15 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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([]))) + rule array_fill{C : context, x : idx, zt : storagetype, var_0 : valtype}: + `%|-%:%`(C, `ARRAY.FILL`_instr(x), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0 I32_valtype]), [], `%`_resulttype([]))) -- 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_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype var_0 I32_valtype]), [], `%`_resulttype([]))) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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))) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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}: @@ -6809,7 +8261,7 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Storagetype_sub: `%|-%<:%`(C, $storagetype_reftype(C.ELEMS_context[$proj_uN_0(y).0]), 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}: + rule array_init_data{C : context, x : idx, y : idx, zt : storagetype, v_numtype : numtype, v_vectype : vectype, var_0 : valtype}: `%|-%:%`(C, `ARRAY.INIT_DATA`_instr(x, y), `%->_%%`_instrtype(`%`_resulttype([REF_valtype(?(NULL_null), _IDX_heaptype(x)) I32_valtype I32_valtype I32_valtype]), [], `%`_resulttype([]))) -- wf_context: `%`(C) -- wf_instr: `%`(`ARRAY.INIT_DATA`_instr(x, y)) @@ -6817,9 +8269,10 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- wf_comptype: `%`(ARRAY_comptype(`%%`_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 ((var_0 = $valtype_numtype(v_numtype)) \/ (var_0 = $valtype_vectype(v_vectype))) -- if ($proj_uN_0(y).0 < |C.DATAS_context|) -- if (C.DATAS_context[$proj_uN_0(y).0] = OK_datatype) + -- fun_unpack: `%%`(zt, var_0) ;; ../../../../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?}: @@ -7296,12 +8749,13 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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_lst : laneidx*}: + rule vshuffle{C : context, sh : bshape, i_lst : laneidx*, var_0 : dim}: `%|-%:%`(C, VSHUFFLE_instr(sh, i_lst), `%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VSHUFFLE_instr(sh, i_lst)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype V128_valtype]), [], `%`_resulttype([V128_valtype]))) - -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0($fun_dim($proj_bshape_0(sh).0)).0)))*{i <- i_lst} + -- (if ($proj_uN_0(i).0 < (2 * $proj_dim_0(var_0).0)))*{i <- i_lst} + -- fun_dim: `%%`($proj_bshape_0(sh).0, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:584.1-585.44 rule vsplat{C : context, sh : shape}: @@ -7311,20 +8765,22 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- 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_opt : sx?, i : laneidx}: + rule vextract_lane{C : context, sh : shape, sx_opt : sx?, i : laneidx, var_0 : dim}: `%|-%:%`(C, VEXTRACT_LANE_instr(sh, sx_opt, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) -- wf_context: `%`(C) -- wf_instr: `%`(VEXTRACT_LANE_instr(sh, sx_opt, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype]), [], `%`_resulttype([$valtype_numtype($unpackshape(sh))]))) - -- if ($proj_uN_0(i).0 < $proj_dim_0($fun_dim(sh)).0) + -- if ($proj_uN_0(i).0 < $proj_dim_0(var_0).0) + -- fun_dim: `%%`(sh, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:591.1-593.21 - rule vreplace_lane{C : context, sh : shape, i : laneidx}: + rule vreplace_lane{C : context, sh : shape, i : laneidx, var_0 : dim}: `%|-%:%`(C, VREPLACE_LANE_instr(sh, i), `%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) -- wf_context: `%`(C) -- wf_instr: `%`(VREPLACE_LANE_instr(sh, i)) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([V128_valtype $valtype_numtype($unpackshape(sh))]), [], `%`_resulttype([V128_valtype]))) - -- if ($proj_uN_0(i).0 < $proj_dim_0($fun_dim(sh)).0) + -- if ($proj_uN_0(i).0 < $proj_dim_0(var_0).0) + -- fun_dim: `%%`(sh, var_0) ;; ../../../../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__}: @@ -7370,7 +8826,7 @@ 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_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*}: + 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, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst ++ x_2_lst, `%`_resulttype(t_3_lst))) -- wf_context: `%`(C) -- wf_instr: `%`(instr_1) @@ -7385,8 +8841,9 @@ relation Instrs_ok: `%|-%:%`(context, instr*, instrtype) -- 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))) + -- if (var_0 =/= ?()) + -- Instrs_ok: `%|-%:%`(!(var_0), instr_2_lst, `%->_%%`_instrtype(`%`_resulttype(t_2_lst), x_2_lst, `%`_resulttype(t_3_lst))) + -- fun_with_locals: `%%%%`(C, x_1_lst, `%%`_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}: @@ -7423,11 +8880,12 @@ relation Expr_ok: `%|-%:%`(context, expr, resulttype) ;; ../../../../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}: + rule mk_Nondefaultable{t : valtype, var_0 : val??}: `|-%NONDEFAULTABLE`(t) -- wf_valtype: `%`(t) - -- if ($default_(t) =/= ?()) - -- if (!($default_(t)) = ?()) + -- if (var_0 =/= ?()) + -- if (!(var_0) = ?()) + -- fun_default_: `%%`(t, var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec relation Instr_const: `%|-%CONST`(context, instr) @@ -7548,23 +9006,25 @@ 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) -- 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)) -- 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)) + -- 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) -- wf_context: `%`(C) -- wf_tag: `%`(TAG_tag(v_tagtype)) -- Tagtype_ok: `%|-%:OK`(C, 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) @@ -7712,11 +9172,12 @@ 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 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) -- wf_context: `%`(C) -- wf_import: `%`(IMPORT_import(name_1, name_2, xt)) -- Externtype_ok: `%|-%:OK`(C, xt) + -- fun_clos_externtype: `%%%`(C, xt, var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Externidx_ok: `%|-%:%`(context, externidx, externtype) @@ -7833,16 +9294,18 @@ 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))) + 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*}: + `%%`(`%%%%%%`_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst), var_0) + -- fun_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)), var_0) -- 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))) ;; ../../../../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_1 : funcidx*, var_0 : moduletype}: + `|-%:%`(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)), var_0) -- wf_context: `%`(C) -- wf_context: `%`(C') -- (wf_name: `%`(nm))*{nm <- nm_lst} @@ -7876,12 +9339,14 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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 (x_lst = var_1) -- 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)) + -- fun_funcidx_nonfuncs: `%%`(`%%%%%%`_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst), var_1) + -- fun_clos_moduletype: `%%%`(C, `%->%`_moduletype(xt_I_lst, xt_E_lst), var_0) ;; ../../../../specification/wasm-3.0/3.0-numerics.relaxed.spectec syntax relaxed2 = @@ -8004,62 +9469,127 @@ def $inv_zbytes_(v_storagetype : storagetype, var_0 : byte*) : lit_ 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 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 -def $fun_sx(v_storagetype : storagetype) : sx?? +relation fun_sx_before_fun_sx_case_7: `%`(storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_6: + `%`(I16_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_5: + `%`(I8_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_4: + `%`(V128_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_3: + `%`(F64_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_2: + `%`(F32_storagetype) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_sx(I32_storagetype) = ?(?()) + rule fun_sx_case_1: + `%`(I64_storagetype) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_0: + `%`(I32_storagetype) + +;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec +relation fun_sx: `%%`(storagetype, sx??) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_sx(I64_storagetype) = ?(?()) + rule fun_sx_case_0: + `%%`(I32_storagetype, ?(?())) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_sx(F32_storagetype) = ?(?()) + rule fun_sx_case_1: + `%%`(I64_storagetype, ?(?())) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_sx(F64_storagetype) = ?(?()) + rule fun_sx_case_2: + `%%`(F32_storagetype, ?(?())) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_sx(V128_storagetype) = ?(?()) + rule fun_sx_case_3: + `%%`(F64_storagetype, ?(?())) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_sx(I8_storagetype) = ?(?(S_sx)) + rule fun_sx_case_4: + `%%`(V128_storagetype, ?(?())) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_sx(I16_storagetype) = ?(?(S_sx)) - def $fun_sx{x0 : storagetype}(x0) = ?() - -- otherwise + rule fun_sx_case_5: + `%%`(I8_storagetype, ?(?(S_sx))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_6: + `%%`(I16_storagetype, ?(?(S_sx))) + + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec + rule fun_sx_case_7{x0 : storagetype}: + `%%`(x0, ?()) + -- ~ fun_sx_before_fun_sx_case_7: `%`(x0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fun_zero(v_lanetype : lanetype) : lane_ +relation fun_zero: `%%`(lanetype, lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_zero(I32_lanetype) = mk_lane__2_lane_(I32_Jnn, `%`_uN(0)) + rule fun_zero_case_0: + `%%`(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 $fun_zero(I64_lanetype) = mk_lane__2_lane_(I64_Jnn, `%`_uN(0)) + rule fun_zero_case_1: + `%%`(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 $fun_zero(I8_lanetype) = mk_lane__2_lane_(I8_Jnn, `%`_uN(0)) + rule fun_zero_case_2: + `%%`(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 $fun_zero(I16_lanetype) = mk_lane__2_lane_(I16_Jnn, `%`_uN(0)) + rule fun_zero_case_3: + `%%`(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 $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)))))) + rule fun_zero_case_4{var_0 : fN}: + `%%`(F32_lanetype, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) + -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + ;; ../../../../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)))))) + rule fun_zero_case_5{var_0 : fN}: + `%%`(F64_lanetype, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) + -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(v_bool : bool) : nat @@ -8093,7 +9623,8 @@ def $ineg_(v_N : N, v_iN : iN) : iN ;; ../../../../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 @@ -8105,13 +9636,18 @@ 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))) + rule fun_iextend__case_0{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)))) + ;; ../../../../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, `%`_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) + -- wf_uN: `%%`(v_N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(v_N : N, v_iN : iN, v_iN_0 : iN) : iN @@ -8132,34 +9668,58 @@ def $imul_(v_N : N, v_iN : iN, v_iN_0 : iN) : iN -- wf_uN: `%%`(v_N, `%`_uN((($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, `%`_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))) + rule fun_idiv__case_1{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))) + ;; ../../../../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, `%`_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, ?()) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_2).0, var_1) + -- fun_signed_: `%%%`(v_N, $proj_uN_0(i_1).0, var_0) + -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) + ;; ../../../../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, ?(`%`_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) + -- wf_uN: `%%`(v_N, `%`_uN(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, `%`_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))) + rule fun_irem__case_1{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))) + ;; ../../../../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, `%`_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)))))))) - -- wf_uN: `%%`(v_N, `%`_uN($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))) + 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, ?(`%`_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, (j_1 - (j_2 * $truncz(((j_1 : int <:> rat) / (j_2 : int <:> rat))))), var_0) + -- wf_uN: `%%`(v_N, `%`_uN(var_0)) + -- if ((j_1 = var_1) /\ (j_2 = var_2)) ;; ../../../../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 @@ -8170,7 +9730,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 @@ -8181,7 +9743,9 @@ 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 @@ -8189,8 +9753,11 @@ def $iadd_sat_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN 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)))) ;; ../../../../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) = `%`_iN(var_0) + -- wf_uN: `%%`(v_N, `%`_uN(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 @@ -8198,8 +9765,11 @@ def $isub_sat_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : iN 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))))) ;; ../../../../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) = `%`_iN(var_0) + -- wf_uN: `%%`(v_N, `%`_uN(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 @@ -8247,15 +9817,17 @@ def $ibitselect_(v_N : N, v_iN : iN, v_iN_0 : iN, v_iN_1 : iN) : iN 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 +relation fun_ieqz_: `%%%`(N, 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))) + rule fun_ieqz__case_0{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)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $inez_(v_N : N, v_iN : iN) : u32 +relation fun_inez_: `%%%`(N, 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))) + rule fun_inez__case_0{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)))) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec @@ -8276,8 +9848,10 @@ def $ilt_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : u32 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)))) ;; ../../../../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) = `%`_u32($bool((var_0 < var_1))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -8285,8 +9859,10 @@ def $igt_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : u32 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)))) ;; ../../../../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) = `%`_u32($bool((var_0 > var_1))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -8294,8 +9870,10 @@ def $ile_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : u32 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)))) ;; ../../../../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) = `%`_u32($bool((var_0 <= var_1))) + -- wf_uN: `%%`(32, `%`_uN($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 @@ -8303,8 +9881,10 @@ def $ige_(v_N : N, v_sx : sx, v_iN : iN, v_iN_0 : iN) : u32 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)))) ;; ../../../../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) = `%`_u32($bool((var_0 >= var_1))) + -- wf_uN: `%%`(32, `%`_uN($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* @@ -8415,273 +9995,454 @@ def $narrow__(v_M : M, v_N : N, v_sx : sx, v_iN : iN) : iN def $reinterpret__(numtype_1 : numtype, numtype_2 : numtype, v_num_ : num_) : num_ ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $lpacknum_(v_lanetype : lanetype, v_num_ : num_) : lane_ +relation fun_lpacknum_: `%%%`(lanetype, 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) + rule fun_lpacknum__case_0{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) + rule fun_lpacknum__case_1{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) + rule fun_lpacknum__case_2{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) + rule fun_lpacknum__case_3{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)) + rule fun_lpacknum__case_4{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)) + rule fun_lpacknum__case_5{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 -def $cpacknum_(v_storagetype : storagetype, v_lit_ : lit_) : lit_ +relation fun_cpacknum_: `%%%`(storagetype, lit_, lit_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(I32_storagetype, c) = c + rule fun_cpacknum__case_0{c : lit_}: + `%%%`(I32_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(I64_storagetype, c) = c + rule fun_cpacknum__case_1{c : lit_}: + `%%%`(I64_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(F32_storagetype, c) = c + rule fun_cpacknum__case_2{c : lit_}: + `%%%`(F32_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(F64_storagetype, c) = c + rule fun_cpacknum__case_3{c : lit_}: + `%%%`(F64_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cpacknum_{c : lit_}(V128_storagetype, c) = c + rule fun_cpacknum__case_4{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)) + rule fun_cpacknum__case_5{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)) + rule fun_cpacknum__case_6{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 -def $lunpacknum_(v_lanetype : lanetype, v_lane_ : lane_) : num_ +relation fun_lunpacknum_: `%%%`(lanetype, 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 + rule fun_lunpacknum__case_0{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 + rule fun_lunpacknum__case_1{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 + rule fun_lunpacknum__case_2{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 + rule fun_lunpacknum__case_3{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)) + rule fun_lunpacknum__case_4{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)) + rule fun_lunpacknum__case_5{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 -def $cunpacknum_(v_storagetype : storagetype, v_lit_ : lit_) : lit_ +relation fun_cunpacknum_: `%%%`(storagetype, lit_, lit_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(I32_storagetype, c) = c + rule fun_cunpacknum__case_0{c : lit_}: + `%%%`(I32_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(I64_storagetype, c) = c + rule fun_cunpacknum__case_1{c : lit_}: + `%%%`(I64_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(F32_storagetype, c) = c + rule fun_cunpacknum__case_2{c : lit_}: + `%%%`(F32_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(F64_storagetype, c) = c + rule fun_cunpacknum__case_3{c : lit_}: + `%%%`(F64_storagetype, c, c) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $cunpacknum_{c : lit_}(V128_storagetype, c) = c + rule fun_cunpacknum__case_4{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)))) + rule fun_cunpacknum__case_5{c : uN, var_0 : consttype?}: + `%%%`(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)))) + -- fun_cunpack: `%%`($storagetype_packtype(I8_packtype), var_0) + -- if (var_0 =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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)))) + rule fun_cunpacknum__case_6{c : uN, var_0 : consttype?}: + `%%%`(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)))) + -- fun_cunpack: `%%`($storagetype_packtype(I16_packtype), var_0) + -- if (var_0 =/= ?()) + -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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 fun_unop_: `%%%%`(numtype, unop_, num_, num_*) ;; ../../../../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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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_6{v_M : nat, i : uN, var_0 : 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, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_M, S_sx, i, var_0) + -- wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, var_0)) + ;; ../../../../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_7{v_M : nat, i : uN, var_0 : 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, var_0)]) + -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_M, S_sx, i, var_0) + -- wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, 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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} ;; ../../../../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_* +relation fun_binop_: `%%%%%`(numtype, binop_, num_, 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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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_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#30)*{iter_0#30 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- lift(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_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#32)*{iter_0#32 <- lift(var_0)}) + -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- lift(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_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#34)*{iter_0#34 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- lift(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_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#36)*{iter_0#36 <- lift(var_0)}) + -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2, var_0) + -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- lift(var_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, 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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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)))] + 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)))]) -- 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 $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)))] + 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)))]) -- 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 $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)))] + 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, `%`_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)))) + ;; ../../../../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)))] + 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, `%`_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)))) + ;; ../../../../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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -def $fun_testop_(v_numtype : numtype, v_testop_ : testop_, v_num_ : num_) : u32 +relation fun_testop_: `%%%%`(numtype, testop_, num_, u32) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_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) + rule fun_testop__case_0{i : uN, var_0 : u32}: + `%%%%`(I32_numtype, mk_testop__0_testop_(I32_Inn, EQZ_testop_Inn), mk_num__0_num_(I32_Inn, i), var_0) + -- fun_ieqz_: `%%%`($sizenn($numtype_addrtype(I32_Inn)), i, var_0) + ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - def $fun_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) + rule fun_testop__case_1{i : uN, var_0 : u32}: + `%%%%`(I64_numtype, mk_testop__0_testop_(I64_Inn, EQZ_testop_Inn), mk_num__0_num_(I64_Inn, i), var_0) + -- fun_ieqz_: `%%%`($sizenn($numtype_addrtype(I64_Inn)), i, var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $fun_relop_(v_numtype : numtype, v_relop_ : relop_, v_num_ : num_, v_num__0 : num_) : u32 @@ -8735,121 +10496,192 @@ 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))] + 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))]) -- 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))) + ;; ../../../../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))] + 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))]) -- 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))) + ;; ../../../../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))] + 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))]) -- 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))) + ;; ../../../../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))] + 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))]) -- 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))) + ;; ../../../../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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))] + 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))]) -- 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 $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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))} + 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#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))} + ;; ../../../../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))] + 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))]) -- 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))) + ;; ../../../../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))] + 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))]) -- 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))) + ;; ../../../../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))] + 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))]) -- 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))) + ;; ../../../../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))] + 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))]) -- 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))) + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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)} + 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#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)} + ;; ../../../../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))]) -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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 $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))]) -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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 $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))]) -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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 $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))]) -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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 $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))]) -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), 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 $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))]) -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), 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 $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))]) -- wf_num_: `%%`($numtype_Fnn(F32_Fnn), 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 $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))]) -- wf_num_: `%%`($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, f_1)) -- if ($size($numtype_Fnn(F64_Fnn)) = $size($numtype_addrtype(I64_Inn))) @@ -8860,202 +10692,392 @@ def $lanes_(v_shape : shape, v_vec_ : vec_) : lane_* 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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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), ?()) + ;; ../../../../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}: + `%%%%`(`%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), ?()) + ;; ../../../../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}: + `%%%%`(`%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), ?()) + ;; ../../../../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}: + `%%%%`(`%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), ?()) ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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) + ;; ../../../../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}: + `%%%%`(`%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) + ;; ../../../../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}: + `%%%%`(`%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) + ;; ../../../../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}: + `%%%%`(`%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) + ;; ../../../../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}: + `%%%%`(`%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) + ;; ../../../../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}: + `%%%%`(`%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) + ;; ../../../../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}: + `%%%%`(`%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) + ;; ../../../../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}: + `%%%%`(`%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) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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?}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)), ?()) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) + ;; ../../../../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}: + `%%%%`(`%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)) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec def $fun_half(v_half : half, nat : nat, nat_0 : nat) : nat @@ -9073,8 +11095,9 @@ def $iswizzle_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 : 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|)]))) + 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 `%`_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)) + -- 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_* @@ -9472,38 +11495,53 @@ def $ivshiftopsx_(v_shape : shape, def $f_(v_N : N, v_sx : sx, v_iN : iN, v_u32 -- if (c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#132)), i)*{c_1#132 <- c_1_lst}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec -def $ivbitmaskop_(v_shape : shape, v_vec_ : vec_) : u32 +relation fun_ivbitmaskop_: `%%%`(shape, vec_, u32) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{v_M : nat, v_1 : uN, c : uN, c_1_lst : lane_*}(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_0{v_M : nat, v_1 : uN, c : uN, c_1_lst : lane_*}: + `%%%`(`%X%`_shape(I32_lanetype, `%`_dim(v_M)), v_1, $irev_(32, c)) -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + -- (if ($proj_lane__2(c_1#133) =/= ?()))*{c_1#133 <- c_1_lst} -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#133)), `%`_iN(0))).0)))*{c_1#133 <- c_1_lst} -- wf_bit: `%`(`%`_bit(0)) -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1)) + -- (if ($proj_lane__2(c_1#135) =/= ?()))*{c_1#135 <- c_1_lst} -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I32_Jnn)), S_sx, !($proj_lane__2(c_1#135)), `%`_iN(0))).0)*{c_1#135 <- c_1_lst} ++ `%`_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{v_M : nat, v_1 : uN, c : uN, c_1_lst : lane_*}(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_1{v_M : nat, v_1 : uN, c : uN, c_1_lst : lane_*}: + `%%%`(`%X%`_shape(I64_lanetype, `%`_dim(v_M)), v_1, $irev_(32, c)) -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + -- (if ($proj_lane__2(c_1#136) =/= ?()))*{c_1#136 <- c_1_lst} -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#136)), `%`_iN(0))).0)))*{c_1#136 <- c_1_lst} -- wf_bit: `%`(`%`_bit(0)) -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1)) + -- (if ($proj_lane__2(c_1#138) =/= ?()))*{c_1#138 <- c_1_lst} -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I64_Jnn)), S_sx, !($proj_lane__2(c_1#138)), `%`_iN(0))).0)*{c_1#138 <- c_1_lst} ++ `%`_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{v_M : nat, v_1 : uN, c : uN, c_1_lst : lane_*}(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_2{v_M : nat, v_1 : uN, c : uN, c_1_lst : lane_*}: + `%%%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), v_1, $irev_(32, c)) -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + -- (if ($proj_lane__2(c_1#139) =/= ?()))*{c_1#139 <- c_1_lst} -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#139)), `%`_iN(0))).0)))*{c_1#139 <- c_1_lst} -- wf_bit: `%`(`%`_bit(0)) -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1)) + -- (if ($proj_lane__2(c_1#141) =/= ?()))*{c_1#141 <- c_1_lst} -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I8_Jnn)), S_sx, !($proj_lane__2(c_1#141)), `%`_iN(0))).0)*{c_1#141 <- c_1_lst} ++ `%`_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivbitmaskop_{v_M : nat, v_1 : uN, c : uN, c_1_lst : lane_*}(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), v_1) = $irev_(32, c) + rule fun_ivbitmaskop__case_3{v_M : nat, v_1 : uN, c : uN, c_1_lst : lane_*}: + `%%%`(`%X%`_shape(I16_lanetype, `%`_dim(v_M)), v_1, $irev_(32, c)) -- wf_uN: `%%`(32, c) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + -- (if ($proj_lane__2(c_1#142) =/= ?()))*{c_1#142 <- c_1_lst} -- (wf_bit: `%`(`%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#142)), `%`_iN(0))).0)))*{c_1#142 <- c_1_lst} -- wf_bit: `%`(`%`_bit(0)) -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1)) + -- (if ($proj_lane__2(c_1#144) =/= ?()))*{c_1#144 <- c_1_lst} -- if ($ibits_(32, c) = `%`_bit($proj_uN_0($ilt_($lsizenn($lanetype_Jnn(I16_Jnn)), S_sx, !($proj_lane__2(c_1#144)), `%`_iN(0))).0)*{c_1#144 <- c_1_lst} ++ `%`_bit(0)^(((32 : nat <:> int) - (v_M : nat <:> int)) : int <:> nat){}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -9546,42 +11584,53 @@ def $ivswizzlop_(v_shape : shape, def $f_(v_N : N, iN*, v_iN : iN) : iN, v_vec_ -- if (c_lst = $f_($lsizenn($lanetype_Jnn(I16_Jnn)), !($proj_lane__2(c_1#156))*{c_1#156 <- c_1_lst}, !($proj_lane__2(c_2#102)))*{c_2#102 <- c_2_lst}) ;; ../../../../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_ +relation fun_ivshufflop_: `%%%%%`(shape, laneidx*, vec_, 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, c_lst : lane_*, c_1_lst : lane_*, c_2_lst : lane_*}(`%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) + rule fun_ivshufflop__case_0{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, c_lst : lane_*, c_1_lst : lane_*, c_2_lst : lane_*}: + `%%%%%`(`%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)) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), c#147))*{c#147 <- c_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), c_1#157))*{c_1#157 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))), c_2#103))*{c_2#103 <- c_2_lst} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v_2)) + -- (if ($proj_uN_0(i#128396).0 < |c_1_lst ++ c_2_lst|))*{i#128396 <- i_lst} -- if (c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i#128396).0]*{i#128396 <- i_lst}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, c_lst : lane_*, c_1_lst : lane_*, c_2_lst : lane_*}(`%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) + rule fun_ivshufflop__case_1{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, c_lst : lane_*, c_1_lst : lane_*, c_2_lst : lane_*}: + `%%%%%`(`%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)) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), c#150))*{c#150 <- c_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), c_1#160))*{c_1#160 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))), c_2#106))*{c_2#106 <- c_2_lst} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v_2)) + -- (if ($proj_uN_0(i#128406).0 < |c_1_lst ++ c_2_lst|))*{i#128406 <- i_lst} -- if (c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i#128406).0]*{i#128406 <- i_lst}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, c_lst : lane_*, c_1_lst : lane_*, c_2_lst : lane_*}(`%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) + rule fun_ivshufflop__case_2{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, c_lst : lane_*, c_1_lst : lane_*, c_2_lst : lane_*}: + `%%%%%`(`%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)) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), c#153))*{c#153 <- c_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), c_1#163))*{c_1#163 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))), c_2#109))*{c_2#109 <- c_2_lst} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v_2)) + -- (if ($proj_uN_0(i#128416).0 < |c_1_lst ++ c_2_lst|))*{i#128416 <- i_lst} -- if (c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i#128416).0]*{i#128416 <- i_lst}) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $ivshufflop_{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, c_lst : lane_*, c_1_lst : lane_*, c_2_lst : lane_*}(`%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) + rule fun_ivshufflop__case_3{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, c_lst : lane_*, c_1_lst : lane_*, c_2_lst : lane_*}: + `%%%%%`(`%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)) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), c#156))*{c#156 <- c_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), c_1#166))*{c_1#166 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))), c_2#112))*{c_2#112 <- c_2_lst} -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v_2)) + -- (if ($proj_uN_0(i#128426).0 < |c_1_lst ++ c_2_lst|))*{i#128426 <- i_lst} -- if (c_lst = c_1_lst ++ c_2_lst[$proj_uN_0(i#128426).0]*{i#128426 <- i_lst}) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec @@ -9606,795 +11655,1245 @@ 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) + rule fun_vunop__case_0{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))) + ;; ../../../../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) + rule fun_vunop__case_1{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))) + ;; ../../../../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) + rule fun_vunop__case_2{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))) + ;; ../../../../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) + rule fun_vunop__case_3{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))) + ;; ../../../../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) + rule fun_vunop__case_4{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))) + ;; ../../../../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) + rule fun_vunop__case_5{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))) + ;; ../../../../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) + rule fun_vunop__case_6{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))) + ;; ../../../../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) + rule fun_vunop__case_7{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))) + ;; ../../../../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) + rule fun_vunop__case_8{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))) + ;; ../../../../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) + rule fun_vunop__case_9{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))) + ;; ../../../../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) + rule fun_vunop__case_10{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))) + ;; ../../../../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) + rule fun_vunop__case_11{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))) + ;; ../../../../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) + rule fun_vunop__case_12{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))) + ;; ../../../../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) + rule fun_vunop__case_13{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))) + ;; ../../../../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) + rule fun_vunop__case_14{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))) + ;; ../../../../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) + rule fun_vunop__case_15{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))) + ;; ../../../../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) + rule fun_vunop__case_16{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))) + ;; ../../../../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) + rule fun_vunop__case_17{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))) + ;; ../../../../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) + rule fun_vunop__case_18{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))) + ;; ../../../../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) + rule fun_vunop__case_19{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))) + ;; ../../../../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) + rule fun_vunop__case_20{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))) + ;; ../../../../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) + rule fun_vunop__case_21{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))) + ;; ../../../../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) + rule fun_vunop__case_22{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))) + ;; ../../../../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) + rule fun_vunop__case_23{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))) + ;; ../../../../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) + rule fun_vunop__case_24{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))) + ;; ../../../../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) + rule fun_vunop__case_25{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))) ;; ../../../../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) + rule fun_vbinop__case_0{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))) + ;; ../../../../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) + rule fun_vbinop__case_1{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))) + ;; ../../../../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) + rule fun_vbinop__case_2{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))) + ;; ../../../../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) + rule fun_vbinop__case_3{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))) + ;; ../../../../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) + rule fun_vbinop__case_4{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))) + ;; ../../../../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) + rule fun_vbinop__case_5{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))) + ;; ../../../../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) + rule fun_vbinop__case_6{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))) + ;; ../../../../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) + rule fun_vbinop__case_7{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))) + ;; ../../../../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) + rule fun_vbinop__case_8{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))) + ;; ../../../../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) + rule fun_vbinop__case_9{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))) + ;; ../../../../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) + rule fun_vbinop__case_10{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))) + ;; ../../../../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) + rule fun_vbinop__case_11{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))) + ;; ../../../../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) + rule fun_vbinop__case_12{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))) + ;; ../../../../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) + rule fun_vbinop__case_13{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))) + ;; ../../../../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) + rule fun_vbinop__case_14{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))) + ;; ../../../../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) + rule fun_vbinop__case_15{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))) + ;; ../../../../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) + rule fun_vbinop__case_16{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))) + ;; ../../../../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) + rule fun_vbinop__case_17{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))) + ;; ../../../../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) + rule fun_vbinop__case_18{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))) + ;; ../../../../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) + rule fun_vbinop__case_19{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))) + ;; ../../../../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) + rule fun_vbinop__case_20{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))) + ;; ../../../../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) + rule fun_vbinop__case_21{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))) + ;; ../../../../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) + rule fun_vbinop__case_22{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))) + ;; ../../../../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) + rule fun_vbinop__case_23{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))) + ;; ../../../../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) + rule fun_vbinop__case_24{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))) + ;; ../../../../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) + rule fun_vbinop__case_25{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))) + ;; ../../../../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) + rule fun_vbinop__case_26{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))) + ;; ../../../../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) + rule fun_vbinop__case_27{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))) + ;; ../../../../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) + rule fun_vbinop__case_28{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))) + ;; ../../../../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) + rule fun_vbinop__case_29{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))) + ;; ../../../../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) + rule fun_vbinop__case_30{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))) + ;; ../../../../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) + rule fun_vbinop__case_31{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))) + ;; ../../../../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) + rule fun_vbinop__case_32{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))) + ;; ../../../../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) + rule fun_vbinop__case_33{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))) + ;; ../../../../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) + rule fun_vbinop__case_34{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))) + ;; ../../../../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) + rule fun_vbinop__case_35{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))) + ;; ../../../../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) + rule fun_vbinop__case_36{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))) + ;; ../../../../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) + rule fun_vbinop__case_37{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))) + ;; ../../../../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) + rule fun_vbinop__case_38{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))) + ;; ../../../../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) + rule fun_vbinop__case_39{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))) + ;; ../../../../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) + rule fun_vbinop__case_40{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))) + ;; ../../../../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) + rule fun_vbinop__case_41{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))) + ;; ../../../../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) + rule fun_vbinop__case_42{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))) + ;; ../../../../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) + rule fun_vbinop__case_43{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))) + ;; ../../../../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) + rule fun_vbinop__case_44{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))) + ;; ../../../../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) + rule fun_vbinop__case_45{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))) + ;; ../../../../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) + rule fun_vbinop__case_46{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))) + ;; ../../../../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) + rule fun_vbinop__case_47{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))) + ;; ../../../../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) + rule fun_vbinop__case_48{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))) + ;; ../../../../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) + rule fun_vbinop__case_49{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))) + ;; ../../../../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) + rule fun_vbinop__case_50{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))) + ;; ../../../../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) + rule fun_vbinop__case_51{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))) + ;; ../../../../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) + rule fun_vbinop__case_52{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))) + ;; ../../../../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) + rule fun_vbinop__case_53{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))) + ;; ../../../../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) + rule fun_vbinop__case_54{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))) + ;; ../../../../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) + rule fun_vbinop__case_55{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))) + ;; ../../../../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) + rule fun_vbinop__case_56{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))) + ;; ../../../../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) + rule fun_vbinop__case_57{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))) + ;; ../../../../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) + rule fun_vbinop__case_58{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))) + ;; ../../../../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) + rule fun_vbinop__case_59{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))) ;; ../../../../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) + rule fun_vternop__case_0{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))) + ;; ../../../../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) + rule fun_vternop__case_1{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))) + ;; ../../../../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) + rule fun_vternop__case_2{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))) + ;; ../../../../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) + rule fun_vternop__case_3{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))) + ;; ../../../../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) + rule fun_vternop__case_4{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))) + ;; ../../../../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) + rule fun_vternop__case_5{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))) + ;; ../../../../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) + rule fun_vternop__case_6{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))) + ;; ../../../../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) + rule fun_vternop__case_7{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))) ;; ../../../../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) + rule fun_vrelop__case_0{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))) + ;; ../../../../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) + rule fun_vrelop__case_1{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))) + ;; ../../../../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) + rule fun_vrelop__case_2{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))) + ;; ../../../../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) + rule fun_vrelop__case_3{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))) + ;; ../../../../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) + rule fun_vrelop__case_4{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))) + ;; ../../../../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) + rule fun_vrelop__case_5{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))) + ;; ../../../../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) + rule fun_vrelop__case_6{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))) + ;; ../../../../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) + rule fun_vrelop__case_7{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))) + ;; ../../../../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) + rule fun_vrelop__case_8{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))) + ;; ../../../../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) + rule fun_vrelop__case_9{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))) + ;; ../../../../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) + rule fun_vrelop__case_10{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))) + ;; ../../../../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) + rule fun_vrelop__case_11{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))) + ;; ../../../../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) + rule fun_vrelop__case_12{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))) + ;; ../../../../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) + rule fun_vrelop__case_13{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))) + ;; ../../../../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) + rule fun_vrelop__case_14{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))) + ;; ../../../../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) + rule fun_vrelop__case_15{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))) + ;; ../../../../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) + rule fun_vrelop__case_16{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))) + ;; ../../../../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) + rule fun_vrelop__case_17{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))) + ;; ../../../../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) + rule fun_vrelop__case_18{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))) + ;; ../../../../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) + rule fun_vrelop__case_19{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))) + ;; ../../../../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) + rule fun_vrelop__case_20{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))) + ;; ../../../../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) + rule fun_vrelop__case_21{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))) + ;; ../../../../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) + rule fun_vrelop__case_22{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))) + ;; ../../../../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) + rule fun_vrelop__case_23{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))) + ;; ../../../../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) + rule fun_vrelop__case_24{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))) + ;; ../../../../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) + rule fun_vrelop__case_25{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))) + ;; ../../../../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) + rule fun_vrelop__case_26{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))) + ;; ../../../../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) + rule fun_vrelop__case_27{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))) + ;; ../../../../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) + rule fun_vrelop__case_28{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))) + ;; ../../../../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) + rule fun_vrelop__case_29{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))) + ;; ../../../../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) + rule fun_vrelop__case_30{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))) + ;; ../../../../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) + rule fun_vrelop__case_31{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))) + ;; ../../../../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) + rule fun_vrelop__case_32{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))) + ;; ../../../../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) + rule fun_vrelop__case_33{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))) + ;; ../../../../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) + rule fun_vrelop__case_34{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))) + ;; ../../../../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) + rule fun_vrelop__case_35{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))) ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I32_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I64_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I8_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : 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, c : 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)]) -- wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c)) -- if (c = $extend__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Jnn(I16_Jnn)), v_sx, c_1)) + ;; ../../../../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, c : fN}(`%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, c : fN}: + `%%%%%`(`%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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), v_sx, c_1)) + ;; ../../../../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, c : fN}(`%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, c : fN}: + `%%%%%`(`%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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), v_sx, c_1)) + ;; ../../../../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, c : fN}(`%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, c : fN}: + `%%%%%`(`%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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), v_sx, c_1)) + ;; ../../../../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, c : fN}(`%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, c : fN}: + `%%%%%`(`%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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), v_sx, c_1)) + ;; ../../../../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, c : fN}(`%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, c : fN}: + `%%%%%`(`%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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I32_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), v_sx, c_1)) + ;; ../../../../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, c : fN}(`%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, c : fN}: + `%%%%%`(`%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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I64_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), v_sx, c_1)) + ;; ../../../../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, c : fN}(`%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, c : fN}: + `%%%%%`(`%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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I8_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), v_sx, c_1)) + ;; ../../../../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, c : fN}(`%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, c : fN}: + `%%%%%`(`%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))]) -- 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 (c = $convert__($lsizenn1($lanetype_Jnn(I16_Jnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#161))?{c#161 <- c_opt}) + rule fun_lcvtop___case_24{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#161))?{c#161 <- c_opt})) -- (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#159))))?{c#159 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#164))?{c#164 <- c_opt}) + rule fun_lcvtop___case_25{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#164))?{c#164 <- c_opt})) -- (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#162))))?{c#162 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#167))?{c#167 <- c_opt}) + rule fun_lcvtop___case_26{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#167))?{c#167 <- c_opt})) -- (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#165))))?{c#165 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#170))?{c#170 <- c_opt}) + rule fun_lcvtop___case_27{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#170))?{c#170 <- c_opt})) -- (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#168))))?{c#168 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#173))?{c#173 <- c_opt}) + rule fun_lcvtop___case_28{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#173))?{c#173 <- c_opt})) -- (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#171))))?{c#171 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#176))?{c#176 <- c_opt}) + rule fun_lcvtop___case_29{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#176))?{c#176 <- c_opt})) -- (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#174))))?{c#174 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#179))?{c#179 <- c_opt}) + rule fun_lcvtop___case_30{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#179))?{c#179 <- c_opt})) -- (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#177))))?{c#177 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#182))?{c#182 <- c_opt}) + rule fun_lcvtop___case_31{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#182))?{c#182 <- c_opt})) -- (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#180))))?{c#180 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#185))?{c#185 <- c_opt}) + rule fun_lcvtop___case_32{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#185))?{c#185 <- c_opt})) -- (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#183))))?{c#183 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#188))?{c#188 <- c_opt}) + rule fun_lcvtop___case_33{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#188))?{c#188 <- c_opt})) -- (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#186))))?{c#186 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#191))?{c#191 <- c_opt}) + rule fun_lcvtop___case_34{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#191))?{c#191 <- c_opt})) -- (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#189))))?{c#189 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#194))?{c#194 <- c_opt}) + rule fun_lcvtop___case_35{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#194))?{c#194 <- c_opt})) -- (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#192))))?{c#192 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#197))?{c#197 <- c_opt}) + rule fun_lcvtop___case_36{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#197))?{c#197 <- c_opt})) -- (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#195))))?{c#195 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#200))?{c#200 <- c_opt}) + rule fun_lcvtop___case_37{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#200))?{c#200 <- c_opt})) -- (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#198))))?{c#198 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#203))?{c#203 <- c_opt}) + rule fun_lcvtop___case_38{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#203))?{c#203 <- c_opt})) -- (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#201))))?{c#201 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#206))?{c#206 <- c_opt}) + rule fun_lcvtop___case_39{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#206))?{c#206 <- c_opt})) -- (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#204))))?{c#204 <- c_opt} -- if (c_opt = $trunc_sat__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#209))?{c#209 <- c_opt}) + rule fun_lcvtop___case_40{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#209))?{c#209 <- c_opt})) -- (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#207))))?{c#207 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#212))?{c#212 <- c_opt}) + rule fun_lcvtop___case_41{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#212))?{c#212 <- c_opt})) -- (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#210))))?{c#210 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#215))?{c#215 <- c_opt}) + rule fun_lcvtop___case_42{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#215))?{c#215 <- c_opt})) -- (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#213))))?{c#213 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#218))?{c#218 <- c_opt}) + rule fun_lcvtop___case_43{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#218))?{c#218 <- c_opt})) -- (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#216))))?{c#216 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#221))?{c#221 <- c_opt}) + rule fun_lcvtop___case_44{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#221))?{c#221 <- c_opt})) -- (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#219))))?{c#219 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#224))?{c#224 <- c_opt}) + rule fun_lcvtop___case_45{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#224))?{c#224 <- c_opt})) -- (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#222))))?{c#222 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#227))?{c#227 <- c_opt}) + rule fun_lcvtop___case_46{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#227))?{c#227 <- c_opt})) -- (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#225))))?{c#225 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#230))?{c#230 <- c_opt}) + rule fun_lcvtop___case_47{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#230))?{c#230 <- c_opt})) -- (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#228))))?{c#228 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#233))?{c#233 <- c_opt}) + rule fun_lcvtop___case_48{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#233))?{c#233 <- c_opt})) -- (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#231))))?{c#231 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#236))?{c#236 <- c_opt}) + rule fun_lcvtop___case_49{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#236))?{c#236 <- c_opt})) -- (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#234))))?{c#234 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#239))?{c#239 <- c_opt}) + rule fun_lcvtop___case_50{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#239))?{c#239 <- c_opt})) -- (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#237))))?{c#237 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#242))?{c#242 <- c_opt}) + rule fun_lcvtop___case_51{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#242))?{c#242 <- c_opt})) -- (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#240))))?{c#240 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I32_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#245))?{c#245 <- c_opt}) + rule fun_lcvtop___case_52{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#245))?{c#245 <- c_opt})) -- (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#243))))?{c#243 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#248))?{c#248 <- c_opt}) + rule fun_lcvtop___case_53{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#248))?{c#248 <- c_opt})) -- (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#246))))?{c#246 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#251))?{c#251 <- c_opt}) + rule fun_lcvtop___case_54{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#251))?{c#251 <- c_opt})) -- (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#249))))?{c#249 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../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, c_opt : iN?}(`%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#254))?{c#254 <- c_opt}) + rule fun_lcvtop___case_55{M_1 : nat, M_2 : nat, v_sx : sx, zero_opt : zero?, c_1 : fN, c_opt : iN?}: + `%%%%%`(`%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#254))?{c#254 <- c_opt})) -- (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#252))))?{c#252 <- c_opt} -- if (c_opt = $relaxed_trunc__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_addrtype(I64_Inn)), v_sx, c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#257))*{c#257 <- c_lst} + rule fun_lcvtop___case_56{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#257))*{c#257 <- c_lst}) -- (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#255))))*{c#255 <- c_lst} -- if (c_lst = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#260))*{c#260 <- c_lst} + rule fun_lcvtop___case_57{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#260))*{c#260 <- c_lst}) -- (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#258))))*{c#258 <- c_lst} -- if (c_lst = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#263))*{c#263 <- c_lst} + rule fun_lcvtop___case_58{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#263))*{c#263 <- c_lst}) -- (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#261))))*{c#261 <- c_lst} -- if (c_lst = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#266))*{c#266 <- c_lst} + rule fun_lcvtop___case_59{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#266))*{c#266 <- c_lst}) -- (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#264))))*{c#264 <- c_lst} -- if (c_lst = $demote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#269))*{c#269 <- c_lst} + rule fun_lcvtop___case_60{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#269))*{c#269 <- c_lst}) -- (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#267))))*{c#267 <- c_lst} -- if (c_lst = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#272))*{c#272 <- c_lst} + rule fun_lcvtop___case_61{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#272))*{c#272 <- c_lst}) -- (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#270))))*{c#270 <- c_lst} -- if (c_lst = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#275))*{c#275 <- c_lst} + rule fun_lcvtop___case_62{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#275))*{c#275 <- c_lst}) -- (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#273))))*{c#273 <- c_lst} -- if (c_lst = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#278))*{c#278 <- c_lst} + rule fun_lcvtop___case_63{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#278))*{c#278 <- c_lst}) -- (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#276))))*{c#276 <- c_lst} -- if (c_lst = $demote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#281))*{c#281 <- c_lst} + rule fun_lcvtop___case_64{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#281))*{c#281 <- c_lst}) -- (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#279))))*{c#279 <- c_lst} -- if (c_lst = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#284))*{c#284 <- c_lst} + rule fun_lcvtop___case_65{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#284))*{c#284 <- c_lst}) -- (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#282))))*{c#282 <- c_lst} -- if (c_lst = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#287))*{c#287 <- c_lst} + rule fun_lcvtop___case_66{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#287))*{c#287 <- c_lst}) -- (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#285))))*{c#285 <- c_lst} -- if (c_lst = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#290))*{c#290 <- c_lst} + rule fun_lcvtop___case_67{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#290))*{c#290 <- c_lst}) -- (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#288))))*{c#288 <- c_lst} -- if (c_lst = $promote__($lsizenn1($lanetype_Fnn(F32_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#293))*{c#293 <- c_lst} + rule fun_lcvtop___case_68{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#293))*{c#293 <- c_lst}) -- (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#291))))*{c#291 <- c_lst} -- if (c_lst = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#296))*{c#296 <- c_lst} + rule fun_lcvtop___case_69{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#296))*{c#296 <- c_lst}) -- (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#294))))*{c#294 <- c_lst} -- if (c_lst = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F32_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#299))*{c#299 <- c_lst} + rule fun_lcvtop___case_70{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#299))*{c#299 <- c_lst}) -- (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#297))))*{c#297 <- c_lst} -- if (c_lst = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) + ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec - def $lcvtop__{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#302))*{c#302 <- c_lst} + rule fun_lcvtop___case_71{M_1 : nat, M_2 : nat, c_1 : fN, c_lst : 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#302))*{c#302 <- c_lst}) -- (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#300))))*{c#300 <- c_lst} -- if (c_lst = $promote__($lsizenn1($lanetype_Fnn(F64_Fnn)), $lsizenn2($lanetype_Fnn(F64_Fnn)), c_1)) ;; ../../../../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, c_1_lst : lane_*, c_lst_lst : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, v_1) = v +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, c_1_lst : lane_*, c_lst_lst : lane_**, var_2_lst : lane_**, var_1 : zero?, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, v_1, v) + -- if (|var_2_lst| = |c_1_lst|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, c_1#171, var_2))*{var_2 <- var_2_lst, c_1#171 <- c_1_lst} + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, var_1) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape(Lnn_1, `%`_dim(v_M))), c_1#169))*{c_1#169 <- c_1_lst} -- (wf_lane_: `%%`(Lnn_2, c#303))*{c#303 <- c_lst#43}*{c_lst#43 <- c_lst_lst} -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(v_M))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(v_M))) - -- 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) = ?())) + -- if ((var_0 = ?()) /\ (var_1 = ?())) -- if (c_1_lst = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(v_M)), v_1)) - -- if (c_lst_lst = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, c_1#171)*{c_1#171 <- c_1_lst})) + -- if (c_lst_lst = $setproduct_(syntax lane_, var_2_lst)) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(v_M)), c_lst#45)*{c_lst#45 <- c_lst_lst}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(v_M)), c_lst#45)*{c_lst#45 <- c_lst_lst}) + ;; ../../../../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, c_1_lst : lane_*, c_lst_lst : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v + 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, c_1_lst : lane_*, c_lst_lst : lane_**, var_1_lst : lane_**, var_0 : half?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- if (|var_1_lst| = |c_1_lst|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- var_1_lst, c_1#174 <- c_1_lst} + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#172))*{c_1#172 <- c_1_lst} -- (wf_lane_: `%%`(Lnn_2, c#306))*{c#306 <- c_lst#46}*{c_lst#46 <- c_lst_lst} -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - -- if ($halfop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(v_half)) + -- if (var_0 = ?(v_half)) -- if (c_1_lst = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$fun_half(v_half, 0, M_2) : M_2]) - -- if (c_lst_lst = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174)*{c_1#174 <- c_1_lst})) + -- if (c_lst_lst = $setproduct_(syntax lane_, var_1_lst)) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#48)*{c_lst#48 <- c_lst_lst}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#48)*{c_lst#48 <- c_lst_lst}) + ;; ../../../../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, c_1_lst : lane_*, c_lst_lst : lane_**}(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1) = v + rule fun_vcvtop___case_2{Lnn_1 : lanetype, M_1 : nat, Lnn_2 : lanetype, M_2 : nat, vcvtop : vcvtop__, v_1 : uN, v : uN, c_1_lst : lane_*, c_lst_lst : lane_**, var_2 : lane_, var_1_lst : lane_**, var_0 : zero?}: + `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) + -- fun_zero: `%%`(Lnn_2, var_2) + -- if (|var_1_lst| = |c_1_lst|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- var_1_lst, c_1#177 <- c_1_lst} + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#175))*{c_1#175 <- c_1_lst} -- (wf_lane_: `%%`(Lnn_2, c#309))*{c#309 <- c_lst#49}*{c_lst#49 <- c_lst_lst} -- wf_shape: `%`(`%X%`_shape(Lnn_1, `%`_dim(M_1))) -- wf_shape: `%`(`%X%`_shape(Lnn_2, `%`_dim(M_2))) - -- if ($zeroop(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop) = ?(ZERO_zero)) + -- if (var_0 = ?(ZERO_zero)) -- if (c_1_lst = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)) - -- if (c_lst_lst = $setproduct_(syntax lane_, $lcvtop__(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177)*{c_1#177 <- c_1_lst} ++ [$fun_zero(Lnn_2)]^M_1{})) + -- if (c_lst_lst = $setproduct_(syntax lane_, var_1_lst ++ [var_2]^M_1{})) + -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#51)*{c_lst#51 <- c_lst_lst}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#51)*{c_lst#51 <- c_lst_lst}) ;; ../../../../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) + rule fun_vshiftop__case_0{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))) + ;; ../../../../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) + rule fun_vshiftop__case_1{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))) + ;; ../../../../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) + rule fun_vshiftop__case_2{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))) + ;; ../../../../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) + rule fun_vshiftop__case_3{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))) + ;; ../../../../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) + rule fun_vshiftop__case_4{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))) + ;; ../../../../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) + rule fun_vshiftop__case_5{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))) + ;; ../../../../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) + rule fun_vshiftop__case_6{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))) + ;; ../../../../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) + rule fun_vshiftop__case_7{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))) ;; ../../../../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) + rule fun_vbitmaskop__case_0{v_M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(v_M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v, var_0) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + ;; ../../../../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) + rule fun_vbitmaskop__case_1{v_M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(v_M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v, var_0) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + ;; ../../../../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) + rule fun_vbitmaskop__case_2{v_M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v, var_0) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + ;; ../../../../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) + rule fun_vbitmaskop__case_3{v_M : nat, v : uN, var_0 : u32}: + `%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(v_M))), v, var_0) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v, var_0) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) ;; ../../../../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) + rule fun_vswizzlop__case_0{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))) + ;; ../../../../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) + rule fun_vswizzlop__case_1{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))) ;; ../../../../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) + rule fun_vshufflop__case_0{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, var_0 : vec_}: + `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), i_lst, v_1, v_2, var_0) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), i_lst, v_1, v_2, var_0) -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M))) ;; ../../../../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_ +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, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_0{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#178))*{c_1#178 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#115))*{c_2#115 <- c_2_lst} @@ -10404,11 +12903,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#1)))*{c'_2#1 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#180) =/= ?()))*{c_1#180 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#180)))*{c_1#180 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#117) =/= ?()))*{c_2#117 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2#117)))*{c_2#117 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#3)*{c'_1#3 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_1{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#181))*{c_1#181 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#118))*{c_2#118 <- c_2_lst} @@ -10418,11 +12921,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#4)))*{c'_2#4 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#183) =/= ?()))*{c_1#183 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#183)))*{c_1#183 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#120) =/= ?()))*{c_2#120 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2#120)))*{c_2#120 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#6)*{c'_1#6 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_2{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#184))*{c_1#184 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#121))*{c_2#121 <- c_2_lst} @@ -10432,11 +12939,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#7)))*{c'_2#7 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#186) =/= ?()))*{c_1#186 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#186)))*{c_1#186 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#123) =/= ?()))*{c_2#123 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2#123)))*{c_2#123 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#9)*{c'_1#9 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_3{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I32_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#187))*{c_1#187 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#124))*{c_2#124 <- c_2_lst} @@ -10446,11 +12957,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I32_Jnn, c'_2#10)))*{c'_2#10 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#189) =/= ?()))*{c_1#189 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_1#189)))*{c_1#189 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#126) =/= ?()))*{c_2#126 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I32_Jnn)), v_sx, !($proj_lane__2(c_2#126)))*{c_2#126 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I32_Jnn, c'_1#12)*{c'_1#12 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_4{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#190))*{c_1#190 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#127))*{c_2#127 <- c_2_lst} @@ -10460,11 +12975,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#13)))*{c'_2#13 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#192) =/= ?()))*{c_1#192 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#192)))*{c_1#192 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#129) =/= ?()))*{c_2#129 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2#129)))*{c_2#129 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#15)*{c'_1#15 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_5{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#193))*{c_1#193 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#130))*{c_2#130 <- c_2_lst} @@ -10474,11 +12993,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#16)))*{c'_2#16 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#195) =/= ?()))*{c_1#195 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#195)))*{c_1#195 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#132) =/= ?()))*{c_2#132 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2#132)))*{c_2#132 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#18)*{c'_1#18 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_6{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#196))*{c_1#196 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#133))*{c_2#133 <- c_2_lst} @@ -10488,11 +13011,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#19)))*{c'_2#19 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#198) =/= ?()))*{c_1#198 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#198)))*{c_1#198 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#135) =/= ?()))*{c_2#135 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2#135)))*{c_2#135 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#21)*{c'_1#21 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_7{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I64_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#199))*{c_1#199 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#136))*{c_2#136 <- c_2_lst} @@ -10502,11 +13029,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I64_Jnn, c'_2#22)))*{c'_2#22 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#201) =/= ?()))*{c_1#201 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_1#201)))*{c_1#201 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#138) =/= ?()))*{c_2#138 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I64_Jnn)), v_sx, !($proj_lane__2(c_2#138)))*{c_2#138 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I64_Jnn, c'_1#24)*{c'_1#24 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_8{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#202))*{c_1#202 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#139))*{c_2#139 <- c_2_lst} @@ -10516,11 +13047,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#25)))*{c'_2#25 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#204) =/= ?()))*{c_1#204 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#204)))*{c_1#204 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#141) =/= ?()))*{c_2#141 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2#141)))*{c_2#141 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#27)*{c'_1#27 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_9{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#205))*{c_1#205 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#142))*{c_2#142 <- c_2_lst} @@ -10530,11 +13065,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#28)))*{c'_2#28 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#207) =/= ?()))*{c_1#207 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#207)))*{c_1#207 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#144) =/= ?()))*{c_2#144 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2#144)))*{c_2#144 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#30)*{c'_1#30 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_10{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#208))*{c_1#208 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#145))*{c_2#145 <- c_2_lst} @@ -10544,11 +13083,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#31)))*{c'_2#31 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#210) =/= ?()))*{c_1#210 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#210)))*{c_1#210 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#147) =/= ?()))*{c_2#147 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2#147)))*{c_2#147 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#33)*{c'_1#33 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_11{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I8_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#211))*{c_1#211 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#148))*{c_2#148 <- c_2_lst} @@ -10558,11 +13101,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I8_Jnn, c'_2#34)))*{c'_2#34 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#213) =/= ?()))*{c_1#213 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_1#213)))*{c_1#213 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#150) =/= ?()))*{c_2#150 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I8_Jnn)), v_sx, !($proj_lane__2(c_2#150)))*{c_2#150 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I8_Jnn, c'_1#36)*{c'_1#36 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_12{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I32_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_1#214))*{c_1#214 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1))), c_2#151))*{c_2#151 <- c_2_lst} @@ -10572,11 +13119,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#37)))*{c'_2#37 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#216) =/= ?()))*{c_1#216 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#216)))*{c_1#216 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#153) =/= ?()))*{c_2#153 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I32_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2#153)))*{c_2#153 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#39)*{c'_1#39 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_13{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I64_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_1#217))*{c_1#217 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1))), c_2#154))*{c_2#154 <- c_2_lst} @@ -10586,11 +13137,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#40)))*{c'_2#40 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#219) =/= ?()))*{c_1#219 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#219)))*{c_1#219 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#156) =/= ?()))*{c_2#156 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I64_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2#156)))*{c_2#156 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#42)*{c'_1#42 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_14{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_1#220))*{c_1#220 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1))), c_2#157))*{c_2#157 <- c_2_lst} @@ -10600,11 +13155,15 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#43)))*{c'_2#43 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#222) =/= ?()))*{c_1#222 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#222)))*{c_1#222 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#159) =/= ?()))*{c_2#159 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I8_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2#159)))*{c_2#159 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#45)*{c'_1#45 <- c'_1_lst} ++ 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, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2) = v + rule fun_vnarrowop___case_15{M_1 : nat, M_2 : nat, v_sx : sx, v_1 : uN, v_2 : uN, v : uN, c_1_lst : lane_*, c_2_lst : lane_*, c'_1_lst : iN*, c'_2_lst : iN*}: + `%%%%%%`(`%X%`_shape(I16_lanetype, `%`_dim(M_1)), `%X%`_shape(I16_lanetype, `%`_dim(M_2)), v_sx, v_1, v_2, v) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_1#223))*{c_1#223 <- c_1_lst} -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1))), c_2#160))*{c_2#160 <- c_2_lst} @@ -10614,7 +13173,9 @@ def $vnarrowop__(shape_1 : shape, shape_2 : shape, v_sx : sx, v_vec_ : vec_, v_v -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2))), mk_lane__2_lane_(I16_Jnn, c'_2#46)))*{c'_2#46 <- c'_2_lst} -- if (c_1_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_1)) -- if (c_2_lst = $lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_1)), v_2)) + -- (if ($proj_lane__2(c_1#225) =/= ?()))*{c_1#225 <- c_1_lst} -- if (c'_1_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_1#225)))*{c_1#225 <- c_1_lst}) + -- (if ($proj_lane__2(c_2#162) =/= ?()))*{c_2#162 <- c_2_lst} -- if (c'_2_lst = $narrow__($lsize($lanetype_Jnn(I16_Jnn)), $lsize($lanetype_Jnn(I16_Jnn)), v_sx, !($proj_lane__2(c_2#162)))*{c_2#162 <- c_2_lst}) -- if (v = $inv_lanes_(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_lane__2_lane_(I16_Jnn, c'_1#48)*{c'_1#48 <- c'_1_lst} ++ mk_lane__2_lane_(I16_Jnn, c'_2#48)*{c'_2#48 <- c'_2_lst})) @@ -10790,69 +13351,100 @@ def $ivextunop__(shape_1 : shape, shape_2 : shape, def $f_(v_N : N, iN*) : iN*, -- if (c_lst = $f_($lsizenn2($lanetype_Jnn(I16_Jnn)), c'_1_lst)) ;; ../../../../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_ +relation fun_vextunop__: `%%%%%`(ishape, ishape, vextunop__, 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) + rule fun_vextunop___case_0{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))) + ;; ../../../../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) + rule fun_vextunop___case_1{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))) + ;; ../../../../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) + rule fun_vextunop___case_2{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))) + ;; ../../../../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) + rule fun_vextunop___case_3{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))) + ;; ../../../../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) + rule fun_vextunop___case_4{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))) + ;; ../../../../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) + rule fun_vextunop___case_5{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))) + ;; ../../../../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) + rule fun_vextunop___case_6{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))) + ;; ../../../../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) + rule fun_vextunop___case_7{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))) + ;; ../../../../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) + rule fun_vextunop___case_8{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))) + ;; ../../../../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) + rule fun_vextunop___case_9{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))) + ;; ../../../../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) + rule fun_vextunop___case_10{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))) + ;; ../../../../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) + rule fun_vextunop___case_11{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))) + ;; ../../../../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) + rule fun_vextunop___case_12{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))) + ;; ../../../../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) + rule fun_vextunop___case_13{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))) + ;; ../../../../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) + rule fun_vextunop___case_14{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))) + ;; ../../../../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) + rule fun_vextunop___case_15{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))) @@ -11105,300 +13697,399 @@ def $ivmul_(v_N : N, var_0 : iN*, var_1 : iN*) : iN* 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 -def $fun_vextbinop__(ishape_1 : ishape, ishape_2 : ishape, v_vextbinop__ : vextbinop__, v_vec_ : vec_, v_vec__0 : vec_) : vec_ +relation fun_vextbinop__: `%%%%%%`(ishape, ishape, vextbinop__, vec_, 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) + rule fun_vextbinop___case_0{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) + rule fun_vextbinop___case_1{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) + rule fun_vextbinop___case_2{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) + rule fun_vextbinop___case_3{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) + rule fun_vextbinop___case_4{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) + rule fun_vextbinop___case_5{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) + rule fun_vextbinop___case_6{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) + rule fun_vextbinop___case_7{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) + rule fun_vextbinop___case_8{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) + rule fun_vextbinop___case_9{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) + rule fun_vextbinop___case_10{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) + rule fun_vextbinop___case_11{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) + rule fun_vextbinop___case_12{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) + rule fun_vextbinop___case_13{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) + rule fun_vextbinop___case_14{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) + rule fun_vextbinop___case_15{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) + rule fun_vextbinop___case_16{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) + rule fun_vextbinop___case_17{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) + rule fun_vextbinop___case_18{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) + rule fun_vextbinop___case_19{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) + rule fun_vextbinop___case_20{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) + rule fun_vextbinop___case_21{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) + rule fun_vextbinop___case_22{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) + rule fun_vextbinop___case_23{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) + rule fun_vextbinop___case_24{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) + rule fun_vextbinop___case_25{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) + rule fun_vextbinop___case_26{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) + rule fun_vextbinop___case_27{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) + rule fun_vextbinop___case_28{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) + rule fun_vextbinop___case_29{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) + rule fun_vextbinop___case_30{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) + rule fun_vextbinop___case_31{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) + rule fun_vextbinop___case_32{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) + rule fun_vextbinop___case_33{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) + rule fun_vextbinop___case_34{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) + rule fun_vextbinop___case_35{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) + rule fun_vextbinop___case_36{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) + rule fun_vextbinop___case_37{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) + rule fun_vextbinop___case_38{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) + rule fun_vextbinop___case_39{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) + rule fun_vextbinop___case_40{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) + rule fun_vextbinop___case_41{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) + rule fun_vextbinop___case_42{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) + rule fun_vextbinop___case_43{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) + rule fun_vextbinop___case_44{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) + rule fun_vextbinop___case_45{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) + rule fun_vextbinop___case_46{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) + rule fun_vextbinop___case_47{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 -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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_M : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11411,11 +14102,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11428,11 +14125,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11445,11 +14148,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11462,11 +14171,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I32_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11479,11 +14194,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11496,11 +14217,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11513,11 +14240,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11530,11 +14263,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I64_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11547,11 +14286,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11564,11 +14309,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11581,11 +14332,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11598,11 +14355,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I8_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11615,11 +14378,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I32_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11632,11 +14401,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I64_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11649,11 +14424,17 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I8_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) + ;; ../../../../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, v_M : nat, c' : uN, c'' : uN}(`%`_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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) + -- 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', var_1) + -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -11666,9 +14447,10 @@ def $fun_vextternop__(ishape_1 : ishape, ishape_2 : ishape, v_vextternop__ : vex -- wf_vbinop_: `%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M_2)), mk_vbinop__0_vbinop_(I16_Jnn, M_2, ADD_vbinop_Jnn_M)) -- if ($jsizenn(v_Jnn) = (2 * $lsizenn1($lanetype_Jnn(I16_Jnn)))) -- if (v_M = (2 * M_2)) - -- if (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)) - -- if (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)) + -- if (c' = var_0) + -- if (c'' = var_1) + -- if (|var_2| > 0) + -- if (c <- var_2) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax num = @@ -11930,300 +14712,798 @@ relation wf_fieldval: `%`(fieldval) `%`(`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)) + rule fieldval_case_7{v_exnaddr : 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)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_9{v_ref : ref}: + `%`(`REF.EXTERN`_fieldval(v_ref)) + -- wf_ref: `%`(v_ref) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fieldval_case_10{v_packtype : packtype, var_0 : iN}: + `%`(PACK_fieldval(v_packtype, var_0)) + -- wf_uN: `%%`($psize(v_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 = + | `%;%`(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)) + -- 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*) + +;; ../../../../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)) + -- wf_state: `%`(v_state) + -- (wf_instr: `%`(v_instr))*{v_instr <- instr_lst} + +;; ../../../../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 +relation fun_packfield__before_fun_packfield__case_9: `%%`(storagetype, val) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_8{i : uN}: + `%%`(I16_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) + -- wf_fieldval: `%`(PACK_fieldval(I16_packtype, $wrap__(32, $psize(I16_packtype), i))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_7{i : uN}: + `%%`(I8_storagetype, CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, i))) + -- wf_fieldval: `%`(PACK_fieldval(I8_packtype, $wrap__(32, $psize(I8_packtype), i))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_6{v_val : val}: + `%%`(I32_storagetype, v_val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_5{v_val : val}: + `%%`(I64_storagetype, v_val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_4{v_val : val}: + `%%`(F32_storagetype, v_val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_3{v_val : val}: + `%%`(F64_storagetype, v_val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_2{v_val : val}: + `%%`(V128_storagetype, v_val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_1{null_opt : null?, v_heaptype : heaptype, v_val : val}: + `%%`(REF_storagetype(null_opt, v_heaptype), v_val) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_0{v_val : val}: + `%%`(BOT_storagetype, v_val) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_packfield_: `%%%`(storagetype, val, fieldval?) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_0{v_val : val}: + `%%%`(BOT_storagetype, v_val, ?($fieldval_val(v_val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_1{null_opt : null?, v_heaptype : heaptype, v_val : val}: + `%%%`(REF_storagetype(null_opt, v_heaptype), v_val, ?($fieldval_val(v_val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_2{v_val : val}: + `%%%`(V128_storagetype, v_val, ?($fieldval_val(v_val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_3{v_val : val}: + `%%%`(F64_storagetype, v_val, ?($fieldval_val(v_val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_4{v_val : val}: + `%%%`(F32_storagetype, v_val, ?($fieldval_val(v_val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_5{v_val : val}: + `%%%`(I64_storagetype, v_val, ?($fieldval_val(v_val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_6{v_val : val}: + `%%%`(I32_storagetype, v_val, ?($fieldval_val(v_val))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_7{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 + rule fun_packfield__case_8{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))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_packfield__case_9{x0 : storagetype, x1 : val}: + `%%%`(x0, x1, ?()) + -- ~ fun_packfield__before_fun_packfield__case_9: `%%`(x0, x1) + +;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec +relation fun_unpackfield__before_fun_unpackfield__case_72: `%%%`(storagetype, sx?, fieldval) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_71{v_sx : sx, i : uN}: + `%%%`(I16_storagetype, ?(v_sx), PACK_fieldval(I16_packtype, i)) + -- wf_val: `%`(CONST_val(I32_numtype, mk_num__0_num_(I32_Inn, $extend__($psize(I16_packtype), 32, v_sx, i)))) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_70{v_sx : sx, i : uN}: + `%%%`(I8_storagetype, ?(v_sx), PACK_fieldval(I8_packtype, 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 + rule fun_unpackfield__case_69{v_numtype : numtype, var_0 : num_}: + `%%%`(I32_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_68{v_numtype : numtype, var_0 : num_}: + `%%%`(I64_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_67{v_numtype : numtype, var_0 : num_}: + `%%%`(F32_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_66{v_numtype : numtype, var_0 : num_}: + `%%%`(F64_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_65{v_numtype : numtype, var_0 : num_}: + `%%%`(V128_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_64{v_numtype : numtype, var_0 : num_, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), CONST_fieldval(v_numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_63{v_numtype : numtype, var_0 : num_}: + `%%%`(BOT_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_62{v_vectype : vectype, var_1 : vec_}: + `%%%`(I32_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_61{v_vectype : vectype, var_1 : vec_}: + `%%%`(I64_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_60{v_vectype : vectype, var_1 : vec_}: + `%%%`(F32_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_59{v_vectype : vectype, var_1 : vec_}: + `%%%`(F64_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_58{v_vectype : vectype, var_1 : vec_}: + `%%%`(V128_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_57{v_vectype : vectype, var_1 : vec_, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), VCONST_fieldval(v_vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_56{v_vectype : vectype, var_1 : vec_}: + `%%%`(BOT_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_55{v_u31 : u31}: + `%%%`(I32_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_54{v_u31 : u31}: + `%%%`(I64_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_53{v_u31 : u31}: + `%%%`(F32_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_52{v_u31 : u31}: + `%%%`(F64_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_51{v_u31 : u31}: + `%%%`(V128_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_50{v_u31 : u31, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), `REF.I31_NUM`_fieldval(v_u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_49{v_u31 : u31}: + `%%%`(BOT_storagetype, ?(), `REF.I31_NUM`_fieldval(v_u31)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_48: + `%%%`(I32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_47: + `%%%`(I64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_46: + `%%%`(F32_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_45: + `%%%`(F64_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_44: + `%%%`(V128_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_43{null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_42: + `%%%`(BOT_storagetype, ?(), `REF.NULL_ADDR`_fieldval) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_41{v_structaddr : structaddr}: + `%%%`(I32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_40{v_structaddr : structaddr}: + `%%%`(I64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_39{v_structaddr : structaddr}: + `%%%`(F32_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_38{v_structaddr : structaddr}: + `%%%`(F64_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_37{v_structaddr : structaddr}: + `%%%`(V128_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_36{v_structaddr : structaddr, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_35{v_structaddr : structaddr}: + `%%%`(BOT_storagetype, ?(), `REF.STRUCT_ADDR`_fieldval(v_structaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_34{v_arrayaddr : arrayaddr}: + `%%%`(I32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_33{v_arrayaddr : arrayaddr}: + `%%%`(I64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_32{v_arrayaddr : arrayaddr}: + `%%%`(F32_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_31{v_arrayaddr : arrayaddr}: + `%%%`(F64_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_30{v_arrayaddr : arrayaddr}: + `%%%`(V128_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_29{v_arrayaddr : arrayaddr, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_28{v_arrayaddr : arrayaddr}: + `%%%`(BOT_storagetype, ?(), `REF.ARRAY_ADDR`_fieldval(v_arrayaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_27{v_funcaddr : funcaddr}: + `%%%`(I32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_26{v_funcaddr : funcaddr}: + `%%%`(I64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) + + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_25{v_funcaddr : funcaddr}: + `%%%`(F32_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_8{v_hostaddr : hostaddr}: - `%`(`REF.HOST_ADDR`_fieldval(v_hostaddr)) + rule fun_unpackfield__case_24{v_funcaddr : funcaddr}: + `%%%`(F64_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_9{v_ref : ref}: - `%`(`REF.EXTERN`_fieldval(v_ref)) - -- wf_ref: `%`(v_ref) + rule fun_unpackfield__case_23{v_funcaddr : funcaddr}: + `%%%`(V128_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - rule fieldval_case_10{v_packtype : packtype, var_0 : iN}: - `%`(PACK_fieldval(v_packtype, var_0)) - -- wf_uN: `%%`($psize(v_packtype), var_0) + rule fun_unpackfield__case_22{v_funcaddr : funcaddr, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax structinst = -{ - TYPE deftype, - FIELDS fieldval* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_21{v_funcaddr : funcaddr}: + `%%%`(BOT_storagetype, ?(), `REF.FUNC_ADDR`_fieldval(v_funcaddr)) -;; ../../../../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} + rule fun_unpackfield__case_20{v_exnaddr : exnaddr}: + `%%%`(I32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax arrayinst = -{ - TYPE deftype, - FIELDS fieldval* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_19{v_exnaddr : exnaddr}: + `%%%`(I64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) -;; ../../../../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} + rule fun_unpackfield__case_18{v_exnaddr : exnaddr}: + `%%%`(F32_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax exninst = -{ - TAG tagaddr, - FIELDS val* -} + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_17{v_exnaddr : exnaddr}: + `%%%`(F64_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) -;; ../../../../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} + rule fun_unpackfield__case_16{v_exnaddr : exnaddr}: + `%%%`(V128_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) -;; ../../../../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 + rule fun_unpackfield__case_15{v_exnaddr : exnaddr, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) -;; ../../../../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} + rule fun_unpackfield__case_14{v_exnaddr : exnaddr}: + `%%%`(BOT_storagetype, ?(), `REF.EXN_ADDR`_fieldval(v_exnaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax state = - | `%;%`(v_store : store, v_frame : frame) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_13{v_hostaddr : hostaddr}: + `%%%`(I32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) -;; ../../../../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)) - -- wf_store: `%`(v_store) - -- wf_frame: `%`(v_frame) + rule fun_unpackfield__case_12{v_hostaddr : hostaddr}: + `%%%`(I64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -syntax config = - | `%;%`(v_state : state, instr_lst : instr*) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec + rule fun_unpackfield__case_11{v_hostaddr : hostaddr}: + `%%%`(F32_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) -;; ../../../../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)) - -- wf_state: `%`(v_state) - -- (wf_instr: `%`(v_instr))*{v_instr <- instr_lst} + rule fun_unpackfield__case_10{v_hostaddr : hostaddr}: + `%%%`(F64_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $Ki : nat ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $Ki = 1024 + rule fun_unpackfield__case_9{v_hostaddr : hostaddr}: + `%%%`(V128_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) -;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $packfield_(v_storagetype : storagetype, v_val : val) : fieldval? ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{v_val : val}(BOT_storagetype, v_val) = ?($fieldval_val(v_val)) + rule fun_unpackfield__case_8{v_hostaddr : hostaddr, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{null_opt : null?, v_heaptype : heaptype, v_val : val}(REF_storagetype(null_opt, v_heaptype), v_val) = ?($fieldval_val(v_val)) + rule fun_unpackfield__case_7{v_hostaddr : hostaddr}: + `%%%`(BOT_storagetype, ?(), `REF.HOST_ADDR`_fieldval(v_hostaddr)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{v_val : val}(V128_storagetype, v_val) = ?($fieldval_val(v_val)) + rule fun_unpackfield__case_6{v_ref : ref}: + `%%%`(I32_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{v_val : val}(F64_storagetype, v_val) = ?($fieldval_val(v_val)) + rule fun_unpackfield__case_5{v_ref : ref}: + `%%%`(I64_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{v_val : val}(F32_storagetype, v_val) = ?($fieldval_val(v_val)) + rule fun_unpackfield__case_4{v_ref : ref}: + `%%%`(F32_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{v_val : val}(I64_storagetype, v_val) = ?($fieldval_val(v_val)) + rule fun_unpackfield__case_3{v_ref : ref}: + `%%%`(F64_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $packfield_{v_val : val}(I32_storagetype, v_val) = ?($fieldval_val(v_val)) + rule fun_unpackfield__case_2{v_ref : ref}: + `%%%`(V128_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) + ;; ../../../../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))) + rule fun_unpackfield__case_1{v_ref : ref, null_opt : null?, v_heaptype : heaptype}: + `%%%`(REF_storagetype(null_opt, v_heaptype), ?(), `REF.EXTERN`_fieldval(v_ref)) + ;; ../../../../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 + rule fun_unpackfield__case_0{v_ref : ref}: + `%%%`(BOT_storagetype, ?(), `REF.EXTERN`_fieldval(v_ref)) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $unpackfield_(v_storagetype : storagetype, var_0 : sx?, v_fieldval : fieldval) : val? +relation fun_unpackfield_: `%%%%`(storagetype, sx?, 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)) + rule fun_unpackfield__case_0{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)) + rule fun_unpackfield__case_1{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)) + rule fun_unpackfield__case_2{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)) + rule fun_unpackfield__case_3{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)) + rule fun_unpackfield__case_4{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)) + rule fun_unpackfield__case_5{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)) + rule fun_unpackfield__case_6{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)) + rule fun_unpackfield__case_7{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)) + rule fun_unpackfield__case_8{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)) + rule fun_unpackfield__case_9{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)) + rule fun_unpackfield__case_10{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)) + rule fun_unpackfield__case_11{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)) + rule fun_unpackfield__case_12{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)) + rule fun_unpackfield__case_13{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)) + rule fun_unpackfield__case_14{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)) + rule fun_unpackfield__case_15{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)) + rule fun_unpackfield__case_16{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)) + rule fun_unpackfield__case_17{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)) + rule fun_unpackfield__case_18{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)) + rule fun_unpackfield__case_19{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)) + rule fun_unpackfield__case_20{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)) + rule fun_unpackfield__case_21{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)) + rule fun_unpackfield__case_22{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)) + rule fun_unpackfield__case_23{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)) + rule fun_unpackfield__case_24{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)) + rule fun_unpackfield__case_25{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)) + rule fun_unpackfield__case_26{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)) + rule fun_unpackfield__case_27{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)) + rule fun_unpackfield__case_28{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)) + rule fun_unpackfield__case_29{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)) + rule fun_unpackfield__case_30{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)) + rule fun_unpackfield__case_31{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)) + rule fun_unpackfield__case_32{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)) + rule fun_unpackfield__case_33{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)) + rule fun_unpackfield__case_34{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)) + rule fun_unpackfield__case_35{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)) + rule fun_unpackfield__case_36{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)) + rule fun_unpackfield__case_37{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)) + rule fun_unpackfield__case_38{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)) + rule fun_unpackfield__case_39{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)) + rule fun_unpackfield__case_40{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)) + rule fun_unpackfield__case_41{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) + rule fun_unpackfield__case_42: + `%%%%`(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) + rule fun_unpackfield__case_43{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) + rule fun_unpackfield__case_44: + `%%%%`(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) + rule fun_unpackfield__case_45: + `%%%%`(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) + rule fun_unpackfield__case_46: + `%%%%`(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) + rule fun_unpackfield__case_47: + `%%%%`(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) + rule fun_unpackfield__case_48: + `%%%%`(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)) + rule fun_unpackfield__case_49{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)) + rule fun_unpackfield__case_50{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)) + rule fun_unpackfield__case_51{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)) + rule fun_unpackfield__case_52{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)) + rule fun_unpackfield__case_53{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)) + rule fun_unpackfield__case_54{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)) + rule fun_unpackfield__case_55{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)) + rule fun_unpackfield__case_56{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 - def $unpackfield_{v_vectype : vectype, var_1 : vec_, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), VCONST_fieldval(v_vectype, var_1)) = ?(VCONST_val(v_vectype, var_1)) + rule fun_unpackfield__case_57{v_vectype : vectype, var_1 : vec_, null_opt : null?, v_heaptype : heaptype}: + `%%%%`(REF_storagetype(null_opt, v_heaptype), ?(), VCONST_fieldval(v_vectype, var_1), ?(VCONST_val(v_vectype, var_1))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_vectype : vectype, var_1 : vec_}(V128_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) = ?(VCONST_val(v_vectype, var_1)) + rule fun_unpackfield__case_58{v_vectype : vectype, var_1 : vec_}: + `%%%%`(V128_storagetype, ?(), VCONST_fieldval(v_vectype, var_1), ?(VCONST_val(v_vectype, var_1))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_vectype : vectype, var_1 : vec_}(F64_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) = ?(VCONST_val(v_vectype, var_1)) + rule fun_unpackfield__case_59{v_vectype : vectype, var_1 : vec_}: + `%%%%`(F64_storagetype, ?(), VCONST_fieldval(v_vectype, var_1), ?(VCONST_val(v_vectype, var_1))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_vectype : vectype, var_1 : vec_}(F32_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) = ?(VCONST_val(v_vectype, var_1)) + rule fun_unpackfield__case_60{v_vectype : vectype, var_1 : vec_}: + `%%%%`(F32_storagetype, ?(), VCONST_fieldval(v_vectype, var_1), ?(VCONST_val(v_vectype, var_1))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_vectype : vectype, var_1 : vec_}(I64_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) = ?(VCONST_val(v_vectype, var_1)) + rule fun_unpackfield__case_61{v_vectype : vectype, var_1 : vec_}: + `%%%%`(I64_storagetype, ?(), VCONST_fieldval(v_vectype, var_1), ?(VCONST_val(v_vectype, var_1))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_vectype : vectype, var_1 : vec_}(I32_storagetype, ?(), VCONST_fieldval(v_vectype, var_1)) = ?(VCONST_val(v_vectype, var_1)) + rule fun_unpackfield__case_62{v_vectype : vectype, var_1 : vec_}: + `%%%%`(I32_storagetype, ?(), VCONST_fieldval(v_vectype, var_1), ?(VCONST_val(v_vectype, var_1))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_numtype : numtype, var_0 : num_}(BOT_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) = ?(CONST_val(v_numtype, var_0)) + rule fun_unpackfield__case_63{v_numtype : numtype, var_0 : num_}: + `%%%%`(BOT_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_numtype : numtype, var_0 : num_, null_opt : null?, v_heaptype : heaptype}(REF_storagetype(null_opt, v_heaptype), ?(), CONST_fieldval(v_numtype, var_0)) = ?(CONST_val(v_numtype, var_0)) + rule fun_unpackfield__case_64{v_numtype : numtype, var_0 : num_, null_opt : null?, v_heaptype : heaptype}: + `%%%%`(REF_storagetype(null_opt, v_heaptype), ?(), CONST_fieldval(v_numtype, var_0), ?(CONST_val(v_numtype, var_0))) + ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $unpackfield_{v_numtype : numtype, var_0 : num_}(V128_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) = ?(CONST_val(v_numtype, var_0)) + rule fun_unpackfield__case_65{v_numtype : numtype, var_0 : num_}: + `%%%%`(V128_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_numtype : numtype, var_0 : num_}(F64_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) = ?(CONST_val(v_numtype, var_0)) + rule fun_unpackfield__case_66{v_numtype : numtype, var_0 : num_}: + `%%%%`(F64_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_numtype : numtype, var_0 : num_}(F32_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) = ?(CONST_val(v_numtype, var_0)) + rule fun_unpackfield__case_67{v_numtype : numtype, var_0 : num_}: + `%%%%`(F32_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_numtype : numtype, var_0 : num_}(I64_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) = ?(CONST_val(v_numtype, var_0)) + rule fun_unpackfield__case_68{v_numtype : numtype, var_0 : num_}: + `%%%%`(I64_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_numtype : numtype, var_0 : num_}(I32_storagetype, ?(), CONST_fieldval(v_numtype, var_0)) = ?(CONST_val(v_numtype, var_0)) + rule fun_unpackfield__case_69{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)))) + rule fun_unpackfield__case_70{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)))) + rule fun_unpackfield__case_71{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 + rule fun_unpackfield__case_72{x0 : storagetype, x1 : sx?, x2 : fieldval}: + `%%%%`(x0, x1, x2, ?()) + -- ~ fun_unpackfield__before_fun_unpackfield__case_72: `%%%`(x0, x1, x2) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec rec { @@ -12416,87 +15696,108 @@ def $fun_local(v_state : state, v_localidx : localidx) : val? 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 $with_local(v_state : state, v_localidx : localidx, v_val : val) : state +relation fun_with_local: `%%%%`(state, localidx, 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)]) + rule fun_with_local_case_0{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 -def $with_global(v_state : state, v_globalidx : globalidx, v_val : val) : state +relation fun_with_global: `%%%%`(state, globalidx, 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)) + rule fun_with_global_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.GLOBALS_moduleinst|) -- 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 -def $with_table(v_state : state, v_tableidx : tableidx, nat : nat, v_ref : ref) : state +relation fun_with_table: `%%%%%`(state, tableidx, nat, 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)) + rule fun_with_table_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.TABLES_moduleinst|) -- 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 -def $with_tableinst(v_state : state, v_tableidx : tableidx, v_tableinst : tableinst) : state +relation fun_with_tableinst: `%%%%`(state, tableidx, 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)) + rule fun_with_tableinst_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.TABLES_moduleinst|) -- 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 -def $with_mem(v_state : state, v_memidx : memidx, nat : nat, nat_0 : nat, var_0 : byte*) : state +relation fun_with_mem: `%%%%%%`(state, memidx, 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_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)) + rule fun_with_mem_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.MEMS_moduleinst|) -- 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))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $with_meminst(v_state : state, v_memidx : memidx, v_meminst : meminst) : state +relation fun_with_meminst: `%%%%`(state, memidx, 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)) + rule fun_with_meminst_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.MEMS_moduleinst|) -- 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 -def $with_elem(v_state : state, v_elemidx : elemidx, var_0 : ref*) : state +relation fun_with_elem: `%%%%`(state, elemidx, ref*, 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)) + rule fun_with_elem_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.ELEMS_moduleinst|) -- wf_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 $with_data(v_state : state, v_dataidx : dataidx, var_0 : byte*) : state +relation fun_with_data: `%%%%`(state, dataidx, byte*, 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)) + rule fun_with_data_case_0{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))) + -- if ($proj_uN_0(x).0 < |$fof(z).MODULE_frame.DATAS_moduleinst|) -- wf_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 $with_struct(v_state : state, v_structaddr : structaddr, nat : nat, v_fieldval : fieldval) : state +relation fun_with_struct: `%%%%%`(state, structaddr, nat, 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)) + rule fun_with_struct_case_0{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(v_state : state, v_arrayaddr : arrayaddr, nat : nat, v_fieldval : fieldval) : state +relation fun_with_array: `%%%%%`(state, arrayaddr, nat, 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)) + rule fun_with_array_case_0{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(v_state : state, var_0 : structinst*) : state +relation fun_add_structinst: `%%%`(state, structinst*, state) ;; ../../../../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)) + rule fun_add_structinst_case_0{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))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_arrayinst(v_state : state, var_0 : arrayinst*) : state +relation fun_add_arrayinst: `%%%`(state, 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)) + rule fun_add_arrayinst_case_0{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))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $add_exninst(v_state : state, var_0 : exninst*) : state +relation fun_add_exninst: `%%%`(state, exninst*, state) ;; ../../../../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)) + rule fun_add_exninst_case_0{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))) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growtable(v_tableinst : tableinst, nat : nat, v_ref : ref) : tableinst? +relation fun_growtable_before_fun_growtable_case_1: `%%%`(tableinst, nat, ref) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growtable{v_tableinst : tableinst, v_n : nat, r : ref, tableinst' : tableinst, at : addrtype, i : uN, j_opt : u64?, rt : reftype, r'_lst : ref*, i' : uN}(v_tableinst, v_n, r) = ?(tableinst') + rule fun_growtable_case_0{v_tableinst : tableinst, v_n : nat, r : ref, tableinst' : tableinst, at : addrtype, i : uN, j_opt : u64?, rt : reftype, r'_lst : ref*, i' : uN}: + `%%%`(v_tableinst, v_n, r) -- 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{}}) @@ -12505,13 +15806,31 @@ def $growtable(v_tableinst : tableinst, nat : nat, v_ref : ref) : tableinst? -- if ($proj_uN_0(i').0 = (|r'_lst| + v_n)) -- (if ($proj_uN_0(i').0 <= $proj_uN_0(j#5).0))?{j#5 <- j_opt} -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) - def $growtable{x0 : tableinst, x1 : nat, x2 : ref}(x0, x1, x2) = ?() - -- otherwise ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec -def $growmem(v_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{v_tableinst : tableinst, v_n : nat, r : ref, tableinst' : tableinst, at : addrtype, i : uN, j_opt : u64?, rt : reftype, r'_lst : ref*, i' : uN}: + `%%%%`(v_tableinst, v_n, r, ?(tableinst')) + -- 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{}}) + -- if (v_tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j_opt), rt), REFS r'_lst}) + -- 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#5).0))?{j#5 <- j_opt} + -- if (($proj_uN_0(i').0 : nat <:> int) <= (((2 ^ $size($numtype_addrtype(at))) : nat <:> int) - (1 : nat <:> int))) + + ;; ../../../../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 fun_growmem_before_fun_growmem_case_1: `%%`(meminst, nat) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec - def $growmem{v_meminst : meminst, v_n : nat, meminst' : meminst, at : addrtype, i : uN, j_opt : u64?, b_lst : byte*, i' : uN}(v_meminst, v_n) = ?(meminst') + rule fun_growmem_case_0{v_meminst : meminst, v_n : nat, meminst' : meminst, at : addrtype, i : uN, j_opt : u64?, b_lst : byte*, i' : uN}: + `%%`(v_meminst, v_n) -- 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)){}}) @@ -12520,8 +15839,25 @@ def $growmem(v_meminst : meminst, nat : nat) : meminst? -- 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#10).0))?{j#10 <- j_opt} -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) - def $growmem{x0 : meminst, x1 : nat}(x0, x1) = ?() - -- otherwise + +;; ../../../../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{v_meminst : meminst, v_n : nat, meminst' : meminst, at : addrtype, i : uN, j_opt : u64?, b_lst : byte*, i' : uN}: + `%%%`(v_meminst, v_n, ?(meminst')) + -- 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)){}}) + -- if (v_meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j_opt)), BYTES b_lst}) + -- if (meminst' = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i', j_opt)), BYTES b_lst ++ `%`_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#10).0))?{j#10 <- j_opt} + -- if ($proj_uN_0(i').0 <= (2 ^ ((($size($numtype_addrtype(at)) : nat <:> int) - (16 : nat <:> int)) : int <:> nat))) + + ;; ../../../../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.1-execution.values.spectec relation Num_ok: `%|-%:%`(store, num, numtype) @@ -12731,29 +16067,39 @@ 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 - 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_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 -def $inst_reftype(v_moduleinst : moduleinst, v_reftype : reftype) : reftype +relation fun_inst_reftype: `%%%`(moduleinst, reftype, reftype) ;; ../../../../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_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 -def $inst_globaltype(v_moduleinst : moduleinst, v_globaltype : globaltype) : globaltype +relation fun_inst_globaltype: `%%%`(moduleinst, globaltype, globaltype) ;; ../../../../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 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 -def $inst_memtype(v_moduleinst : moduleinst, v_memtype : memtype) : memtype +relation fun_inst_memtype: `%%%`(moduleinst, memtype, memtype) ;; ../../../../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_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_tabletype(v_moduleinst : moduleinst, v_tabletype : tabletype) : tabletype +relation fun_inst_tabletype: `%%%`(moduleinst, tabletype, 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 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.3-execution.instructions.spectec relation Step_pure_before_br_on_null_addr: `%`(instr*) @@ -13186,49 +16532,54 @@ 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)]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(CONST_instr(nt, c)) - -- if (|$fun_unop_(nt, unop, c_1)| > 0) - -- if (c <- $fun_unop_(nt, unop, c_1)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(UNOP_instr(nt, unop)) -- wf_instr: `%`(TRAP_instr) - -- if ($fun_unop_(nt, unop, c_1) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- if (|$fun_binop_(nt, binop, c_1, c_2)| > 0) - -- if (c <- $fun_binop_(nt, binop, c_1, c_2)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(CONST_instr(nt, c_2)) -- wf_instr: `%`(BINOP_instr(nt, binop)) -- wf_instr: `%`(TRAP_instr) - -- if ($fun_binop_(nt, binop, c_1, c_2) = []) + -- if (var_0 = []) + -- 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_}: + rule testop{nt : numtype, c_1 : num_, testop : testop_, c : num_, var_0 : u32}: `%~>%`([CONST_instr(nt, c_1) TESTOP_instr(nt, testop)], [CONST_instr(I32_numtype, c)]) -- wf_instr: `%`(CONST_instr(nt, c_1)) -- wf_instr: `%`(TESTOP_instr(nt, testop)) -- wf_instr: `%`(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)) = var_0) + -- fun_testop_: `%%%%`(nt, testop, c_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule relop{nt : numtype, c_1 : num_, c_2 : num_, relop : relop_, c : num_}: @@ -13241,21 +16592,23 @@ relation Step_pure: `%~>%`(instr*, instr*) -- if (!($proj_num__0(c)) = $fun_relop_(nt, relop, c_1, c_2)) ;; ../../../../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)]) -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(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 (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(CONST_instr(nt_1, c_1)) -- wf_instr: `%`(CVTOP_instr(nt_2, nt_1, cvtop)) -- wf_instr: `%`(TRAP_instr) - -- if ($fun_cvtop__(nt_1, nt_2, cvtop, c_1) = []) + -- if (var_0 = []) + -- 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_}: @@ -13288,73 +16641,80 @@ relation Step_pure: `%~>%`(instr*, instr*) -- if (c <- $vvternop_(V128_vectype, v_vvternop, c_1, c_2, c_3)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule vvtestop{c_1 : vec_, c : num_}: + rule vvtestop{c_1 : vec_, c : num_, var_0 : u32}: `%~>%`([VCONST_instr(V128_vectype, c_1) VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)], [CONST_instr(I32_numtype, c)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VVTESTOP_instr(V128_vectype, ANY_TRUE_vvtestop)) -- wf_instr: `%`(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)) = var_0) + -- fun_inez_: `%%%`($vsize(V128_vectype), c_1, var_0) ;; ../../../../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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (|$fun_vunop_(sh, vunop, c_1)| > 0) - -- if (c <- $fun_vunop_(sh, vunop, c_1)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VUNOP_instr(sh, vunop)) -- wf_instr: `%`(TRAP_instr) - -- if ($fun_vunop_(sh, vunop, c_1) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- if (|$fun_vbinop_(sh, vbinop, c_1, c_2)| > 0) - -- if (c <- $fun_vbinop_(sh, vbinop, c_1, c_2)) + -- if (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- 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) - -- if ($fun_vbinop_(sh, vbinop, c_1, c_2) = []) + -- if (var_0 = []) + -- 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)]) -- 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)) - -- 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 (|var_0| > 0) + -- if (c <- var_0) + -- 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]) -- 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) - -- if ($fun_vternop_(sh, vternop, c_1, c_2, c_3) = []) + -- if (var_0 = []) + -- 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_*}: + rule vtestop{c_1 : vec_, v_Jnn : Jnn, v_M : M, c : num_, i_lst : lane_*, var_0_lst : uN*}: `%~>%`([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)]) -- (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)) @@ -13363,63 +16723,71 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) -- if (i_lst = $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), c_1)) -- if ($proj_num__0(c) =/= ?()) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0(var_0).0*{var_0 <- var_0_lst})) + -- if (|var_0_lst| = |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})) + -- (fun_inez_: `%%%`($jsizenn(v_Jnn), !($proj_lane__2(i)), var_0))*{var_0 <- var_0_lst, i <- i_lst} ;; ../../../../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)]) -- 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)) - -- if (c = $fun_vrelop_(sh, vrelop, c_1, c_2)) + -- if (c = var_0) + -- 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)]) -- 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)) + -- if (c = var_0) -- if ($proj_num__0(i) =/= ?()) - -- if (c = $fun_vshiftop_(sh, vshiftop, c_1, !($proj_num__0(i)))) + -- 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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VBITMASK_instr(sh)) -- wf_instr: `%`(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) + -- 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)]) -- 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)) - -- if (c = $fun_vswizzlop_(sh, swizzlop, c_1, c_2)) + -- if (c = var_0) + -- 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)]) -- 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)) - -- if (c = $vshufflop_(sh, i_lst, c_1, c_2)) + -- if (c = var_0) + -- 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_}: + rule vsplat{v_Lnn : Lnn, c_1 : num_, v_M : M, c : vec_, var_0 : lane_}: `%~>%`([CONST_instr($lunpack(v_Lnn), c_1) VSPLAT_instr(`%X%`_shape(v_Lnn, `%`_dim(v_M)))], [VCONST_instr(V128_vectype, c)]) -- wf_instr: `%`(CONST_instr($lunpack(v_Lnn), c_1)) -- wf_instr: `%`(VSPLAT_instr(`%X%`_shape(v_Lnn, `%`_dim(v_M)))) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape(v_Lnn, `%`_dim(v_M))) - -- if (c = $inv_lanes_(`%X%`_shape(v_Lnn, `%`_dim(v_M)), $lpacknum_(v_Lnn, c_1)^v_M{})) + -- if (c = $inv_lanes_(`%X%`_shape(v_Lnn, `%`_dim(v_M)), var_0^v_M{})) + -- fun_lpacknum_: `%%%`(v_Lnn, c_1, var_0) ;; ../../../../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_}: @@ -13445,92 +16813,103 @@ relation Step_pure: `%~>%`(instr*, instr*) -- 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])))) ;; ../../../../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_}: + rule vreplace_lane{c_1 : vec_, v_Lnn : Lnn, c_2 : num_, v_M : M, i : laneidx, c : vec_, var_0 : lane_}: `%~>%`([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)]) -- 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: `%`(VCONST_instr(V128_vectype, c)) -- wf_shape: `%`(`%X%`_shape(v_Lnn, `%`_dim(v_M))) - -- 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)])) + -- 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] = var_0])) + -- fun_lpacknum_: `%%%`(v_Lnn, c_2, var_0) ;; ../../../../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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VEXTUNOP_instr(sh_2, sh_1, vextunop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if ($fun_vextunop__(sh_1, sh_2, vextunop, c_1) = c) + -- if (var_0 = 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)]) -- 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)) - -- if ($fun_vextbinop__(sh_1, sh_2, vextbinop, c_1, c_2) = c) + -- if (var_0 = 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)]) -- 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)) - -- if ($fun_vextternop__(sh_1, sh_2, vextternop, c_1, c_2, c_3) = c) + -- if (var_0 = 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)]) -- 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)) - -- 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) + -- 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)]) -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) -- wf_instr: `%`(VCVTOP_instr(sh_2, sh_1, vcvtop)) -- wf_instr: `%`(VCONST_instr(V128_vectype, c)) - -- if (c = $fun_vcvtop__(sh_1, sh_2, vcvtop, c_1)) + -- if (c = var_0) + -- 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)) + rule fun_blocktype__case_0{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))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) -- Expand: `%~~%`($fun_type(z, x), `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + ;; ../../../../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))) + rule fun_blocktype__case_1{z : state, t_opt : valtype?}: + `%%%`(z, _RESULT_blocktype(t_opt), `%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t_opt)))) -- wf_instrtype: `%`(`%->_%%`_instrtype(`%`_resulttype([]), [], `%`_resulttype(lift(t_opt)))) ;; ../../../../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, rt : reftype}: + rule br_on_cast_succeed_0{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_reftype: `%`(rt) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, v_ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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, rt : reftype}: + rule br_on_cast_fail_succeed_0{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_reftype: `%`(rt) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, v_ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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) @@ -13749,13 +17128,13 @@ relation Step_read_before_memory_copy_le: `%`(config) ;; ../../../../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, v_n : n, x_1 : idx, x_2 : idx}: + rule memory_copy_le_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, var_0 : memarg}: `%`(`%;%`_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: `%`(`%;%`_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), 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: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) -- if ($proj_num__0(i_1) =/= ?()) -- 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))))) -- if ($proj_num__0(i_2) =/= ?()) @@ -13764,6 +17143,7 @@ relation Step_read_before_memory_copy_gt: `%`(config) -- wf_instr: `%`(`MEMORY.COPY`_instr(x_1, x_2)) -- ~ Step_read_before_memory_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))) `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) + -- fun_memarg0: `%`(var_0) ;; ../../../../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, v_n : n, x_1 : idx, x_2 : idx}: @@ -13813,25 +17193,27 @@ relation Step_read_before_memory_init_succ: `%`(config) ;; ../../../../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, rt' : reftype}: + rule ref_test_true_0{s : store, f : frame, v_ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)])) -- wf_reftype: `%`(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)))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, v_ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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, rt' : reftype}: + rule ref_cast_succeed_0{s : store, f : frame, v_ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) -- wf_reftype: `%`(rt') -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, v_ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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) @@ -13912,7 +17294,7 @@ relation Step_read_before_array_copy_le: `%`(config) ;; ../../../../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}: + 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, var_0 : sx??}: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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: `%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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)) @@ -13930,8 +17312,9 @@ relation Step_read_before_array_copy_gt: `%`(config) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_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))) - -- 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)))) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx_opt = !(var_0))) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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}: @@ -14006,15 +17389,16 @@ relation Step_read_before_array_init_elem_succ: `%`(config) ;; ../../../../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}: + 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, var_0 : nat?}: `%`(`%;%`_config(z, [`REF.ARRAY_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: `%`(`%;%`_config(z, [`REF.ARRAY_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: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- 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|) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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}: @@ -14035,15 +17419,16 @@ relation Step_read_before_array_init_data_num: `%`(config) -- if (v_n = 0) ;; ../../../../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}: + 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, var_0 : nat?}: `%`(`%;%`_config(z, [`REF.ARRAY_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: `%`(`%;%`_config(z, [`REF.ARRAY_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: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- 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|) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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}: @@ -14057,30 +17442,33 @@ relation Step_read_before_array_init_data_num: `%`(config) ;; ../../../../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*}: + 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}: `%~>%`(`%;%`_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)]) -- wf_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))) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(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*}: + 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}: `%~>%`(`%;%`_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)]) -- wf_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))) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(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, rt : reftype}: + rule br_on_cast_succeed{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : reftype, var_0 : 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)]) -- wf_reftype: `%`(rt) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_instr(l, rt_1, rt_2)])) -- wf_instr: `%`(BR_instr(l)) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, v_ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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}: @@ -14089,13 +17477,14 @@ relation Step_read: `%~>%`(config, instr*) -- ~ Step_read_before_br_on_cast_fail: `%`(`%;%`_config(`%;%`_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, rt : reftype}: + rule br_on_cast_fail_succeed{s : store, f : frame, v_ref : ref, l : labelidx, rt_1 : reftype, rt_2 : reftype, rt : reftype, var_0 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)]), [$instr_ref(v_ref)]) -- wf_reftype: `%`(rt) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) BR_ON_CAST_FAIL_instr(l, rt_1, rt_2)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, v_ref, rt) - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, $inst_reftype(f.MODULE_frame, rt_2)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt, var_0) + -- 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}: @@ -14121,19 +17510,21 @@ relation Step_read: `%~>%`(config, instr*) -- 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*}: + 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*, var_0_lst : val??*}: `%~>%`(`%;%`_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)])]) -- wf_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_funccode: `%`(FUNC_funccode(x, LOCAL_local(t)*{t <- t_lst}, instr_lst)) - -- (if ($default_(t) =/= ?()))*{t <- t_lst} - -- wf_frame: `%`({LOCALS ?(v_val)^v_n{v_val <- val_lst} ++ !($default_(t))*{t <- t_lst}, MODULE fi.MODULE_funcinst}) + -- (if (var_0 =/= ?()))*{var_0 <- var_0_lst} + -- wf_frame: `%`({LOCALS ?(v_val)^v_n{v_val <- val_lst} ++ !(var_0)*{var_0 <- var_0_lst}, MODULE fi.MODULE_funcinst}) -- if (a < |$fun_funcinst(z)|) -- if ($fun_funcinst(z)[a] = fi) -- Expand: `%~~%`(fi.TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) -- if (fi.CODE_funcinst = FUNC_funccode(x, LOCAL_local(t)*{t <- t_lst}, instr_lst)) - -- if (f = {LOCALS ?(v_val)^v_n{v_val <- val_lst} ++ !($default_(t))*{t <- t_lst}, MODULE fi.MODULE_funcinst}) + -- if (f = {LOCALS ?(v_val)^v_n{v_val <- val_lst} ++ !(var_0)*{var_0 <- var_0_lst}, MODULE fi.MODULE_funcinst}) + -- if (|var_0_lst| = |t_lst|) + -- (fun_default_: `%%`(t, var_0))*{var_0 <- var_0_lst, t <- t_lst} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule return_call{z : state, x : idx, a : addr}: @@ -14252,12 +17643,13 @@ relation Step_read: `%~>%`(config, 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])])) ;; ../../../../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*}: + 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}: `%~>%`(`%;%`_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)])]) -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_m{v_val <- val_lst} ++ [TRY_TABLE_instr(bt, `%`_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))) - -- if ($blocktype_(z, bt) = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- if (var_0 = `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(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}: @@ -14556,16 +17948,17 @@ relation Step_read: `%~>%`(config, instr*) -- if (v_n = 0) ;; ../../../../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)]) + rule memory_fill_succ{z : state, at : addrtype, i : num_, v_val : val, v_n : n, x : idx, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) 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) =/= ?()) -- 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_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: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, var_0)) -- 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)) -- ~ Step_read_before_memory_fill_succ: `%`(`%;%`_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)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../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}: @@ -14584,37 +17977,39 @@ relation Step_read: `%~>%`(config, instr*) -- if (v_n = 0) ;; ../../../../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)]) + 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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0) 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) =/= ?()) -- 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), 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: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) -- 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)) -- ~ Step_read_before_memory_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))) `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) + -- fun_memarg0: `%`(var_0) ;; ../../../../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)]) + 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, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0) 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)]) -- 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(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_instr: `%`(LOAD_instr(I32_numtype, ?(mk_loadop__0_loadop_(I32_Inn, `%_%`_loadop_Inn(`%`_sz(8), U_sx))), x_2, var_0)) + -- wf_instr: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x_1, var_0)) -- 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)) -- ~ Step_read_before_memory_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))) `MEMORY.COPY`_instr(x_1, x_2)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../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}: @@ -14633,20 +18028,21 @@ relation Step_read: `%~>%`(config, instr*) -- if (v_n = 0) ;; ../../../../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)]) + rule memory_init_succ{z : state, at : addrtype, i : num_, j : num_, v_n : n, x : idx, y : idx, var_0 : memarg}: + `%~>%`(`%;%`_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, var_0) 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) =/= ?()) -- 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_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: `%`(STORE_instr(I32_numtype, ?(mk_storeop__0_storeop_(I32_Inn, `%`_storeop_Inn(`%`_sz(8)))), x, var_0)) -- 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)) -- ~ Step_read_before_memory_init_succ: `%`(`%;%`_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)])) + -- fun_memarg0: `%`(var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule ref_null{z : state, ht : heaptype}: @@ -14662,14 +18058,15 @@ relation Step_read: `%~>%`(config, instr*) -- 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, rt' : reftype}: + rule ref_test_true{s : store, f : frame, v_ref : ref, rt : reftype, rt' : reftype, var_0 : 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)))]) -- wf_reftype: `%`(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)))) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, v_ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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}: @@ -14679,13 +18076,14 @@ relation Step_read: `%~>%`(config, instr*) -- ~ Step_read_before_ref_test_false: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.TEST`_instr(rt)])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule ref_cast_succeed{s : store, f : frame, v_ref : ref, rt : reftype, rt' : reftype}: + rule ref_cast_succeed{s : store, f : frame, v_ref : ref, rt : reftype, rt' : reftype, var_0 : reftype}: `%~>%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)]), [$instr_ref(v_ref)]) -- wf_reftype: `%`(rt') -- wf_config: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) -- wf_context: `%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}) -- Ref_ok: `%|-%:%`(s, v_ref, rt') - -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', $inst_reftype(f.MODULE_frame, rt)) + -- Reftype_sub: `%|-%<:%`({TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], LOCALS [], LABELS [], RETURN ?(), REFS [], RECS []}, rt', var_0) + -- 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}: @@ -14695,16 +18093,20 @@ relation Step_read: `%~>%`(config, instr*) -- ~ Step_read_before_ref_cast_fail: `%`(`%;%`_config(`%;%`_state(s, f), [$instr_ref(v_ref) `REF.CAST`_instr(rt)])) ;; ../../../../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*}: + rule struct_new_default{z : state, x : idx, val_lst : val*, mut_opt_lst : mut?*, zt_lst : storagetype*, var_1_lst : valtype*, var_0_lst : val??*}: `%~>%`(`%;%`_config(z, [`STRUCT.NEW_DEFAULT`_instr(x)]), $instr_val(v_val)*{v_val <- val_lst} ++ [`STRUCT.NEW`_instr(x)]) -- (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}))) -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_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} + -- if (|var_0_lst| = |val_lst|) + -- (if (var_0 =/= ?()))*{var_0 <- var_0_lst} + -- (if (!(var_0) = ?(v_val)))*{var_0 <- var_0_lst, v_val <- val_lst} + -- if (|var_1_lst| = |zt_lst|) + -- (fun_unpack: `%%`(zt, var_1))*{var_1 <- var_1_lst, zt <- zt_lst} + -- if (|var_1_lst| = |var_0_lst|) + -- (fun_default_: `%%`(var_1, var_0))*{var_1 <- var_1_lst, var_0 <- var_0_lst} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule struct_get_null{z : state, sx_opt : sx?, x : idx, i : fieldidx}: @@ -14713,26 +18115,29 @@ relation Step_read: `%~>%`(config, instr*) -- 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])))]) - -- 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)|) + rule struct_get_struct{z : state, a : addr, sx_opt : sx?, x : idx, i : fieldidx, zt_lst : storagetype*, mut_opt_lst : mut?*, var_0 : val?}: + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) `STRUCT.GET`_instr(sx_opt, x, i)]), [$instr_val(!(var_0))]) + -- if (var_0 =/= ?()) -- 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}))) -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- 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)|) + -- fun_unpackfield_: `%%%%`(zt_lst[$proj_uN_0(i).0], sx_opt, $fun_structinst(z)[a].FIELDS_structinst[$proj_uN_0(i).0], var_0) ;; ../../../../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}: + rule array_new_default{z : state, v_n : n, x : idx, v_val : val, mut_opt : mut?, zt : storagetype, var_1 : valtype, var_0 : val??}: `%~>%`(`%;%`_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))]) -- 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))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- if ($default_($unpack(zt)) =/= ?()) - -- if (!($default_($unpack(zt))) = ?(v_val)) + -- if (var_0 =/= ?()) + -- if (!(var_0) = ?(v_val)) + -- fun_unpack: `%%`(zt, var_1) + -- fun_default_: `%%`(var_1, var_0) ;; ../../../../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}: @@ -14752,28 +18157,33 @@ relation Step_read: `%~>%`(config, instr*) -- if (ref_lst = $fun_elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : v_n]) ;; ../../../../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}: + rule array_new_data_oob{z : state, i : num_, v_n : n, x : idx, y : idx, mut_opt : mut?, zt : storagetype, var_0 : nat?}: `%~>%`(`%;%`_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]) -- 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: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- 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|) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((v_n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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{} + rule array_new_data_num{z : state, i : num_, v_n : n, x : idx, y : idx, zt : storagetype, c_lst : lit_*, mut_opt : mut?, var_3 : nat?, var_2_lst : lit_*, var_1 : consttype?, var_0_lst : instr*}: + `%~>%`(`%;%`_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)]), var_0_lst ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))]) -- (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))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- if ($zsize(zt) =/= ?()) + -- if (var_3 =/= ?()) -- 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)]) + -- if ($concatn_(syntax byte, $zbytes_(zt, c)^v_n{c <- c_lst}, (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((v_n * !(var_3)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- fun_zsize: `%%`(zt, var_3) + -- (fun_cunpacknum_: `%%%`(zt, c, var_2))^v_n{var_2 <- var_2_lst, c <- c_lst} + -- fun_cunpack: `%%`(zt, var_1) + -- (if (var_1 =/= ?()))^v_n{} + -- (fun_const: `%%%`(!(var_1), var_2, var_0))^v_n{var_2 <- var_2_lst, var_0 <- var_0_lst} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_get_null{z : state, i : num_, sx_opt : sx?, x : idx}: @@ -14791,15 +18201,16 @@ relation Step_read: `%~>%`(config, instr*) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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])))]) - -- 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) =/= ?()) + rule array_get_array{z : state, a : addr, i : num_, sx_opt : sx?, x : idx, zt : storagetype, mut_opt : mut?, var_0 : val?}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) `ARRAY.GET`_instr(sx_opt, x)]), [$instr_val(!(var_0))]) + -- if (var_0 =/= ?()) -- 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))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- 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) =/= ?()) + -- fun_unpackfield_: `%%%%`(zt, sx_opt, $fun_arrayinst(z)[a].FIELDS_arrayinst[$proj_uN_0(!($proj_num__0(i))).0], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_len_null{z : state}: @@ -14887,7 +18298,7 @@ relation Step_read: `%~>%`(config, instr*) -- if (v_n = 0) ;; ../../../../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}: + 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, var_0 : sx??}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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)]) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -14905,11 +18316,12 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_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))) - -- 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)))) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx_opt = !(var_0))) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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}: + 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, var_0 : sx??}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a_1) CONST_instr(I32_numtype, 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)]) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -14927,8 +18339,9 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_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))) + -- if (var_0 =/= ?()) + -- if (sx_opt = !(var_0)) + -- fun_sx: `%%`(zt_2, var_0) ;; ../../../../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}: @@ -14994,15 +18407,16 @@ relation Step_read: `%~>%`(config, instr*) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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}: + 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, var_0 : nat?}: `%~>%`(`%;%`_config(z, [`REF.ARRAY_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]) -- 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: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- 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|) + -- if (var_0 =/= ?()) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) + -- fun_zsize: `%%`(zt, var_0) ;; ../../../../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}: @@ -15012,25 +18426,29 @@ relation Step_read: `%~>%`(config, instr*) -- if (v_n = 0) ;; ../../../../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) =/= ?()) + 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?, var_3 : nat?, var_2 : lit_, var_1 : consttype?, var_0 : 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(v_n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 + (((!(var_3) : 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 ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if ($zsize(zt) =/= ?()) + -- if (var_3 =/= ?()) -- 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_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(($proj_uN_0(!($proj_num__0(j))).0 + (((!(var_3) : 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))) -- ~ 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)]) + -- if ($zbytes_(zt, c) = $fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(j))).0 : (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) + -- fun_zsize: `%%`(zt, var_3) + -- fun_cunpacknum_: `%%%`(zt, c, var_2) + -- fun_cunpack: `%%`(zt, var_1) + -- if (var_1 =/= ?()) + -- fun_const: `%%%`(!(var_1), var_2, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rec { @@ -15089,29 +18507,33 @@ relation Step: `%~>%`(config, config) -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr_lst), `%;%`_config(`%;%`_state(s', f''), instr'_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:231.1-235.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])) + rule throw{z : state, v_n : n, val_lst : val*, x : idx, exn : exninst, a : addr, t_lst : valtype*, var_1 : deftype?, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [THROW_instr(x)]), `%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- 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_config: `%`(`%;%`_config(var_0, [`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_exninst: `%`({TAG $fun_tagaddr(z)[$proj_uN_0(x).0], FIELDS val_lst}) - -- 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 (var_1 =/= ?()) + -- Expand: `%~~%`(!(var_1), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) -- if (a = |$fun_exninst(z)|) -- if (exn = {TAG $fun_tagaddr(z)[$proj_uN_0(x).0], FIELDS val_lst}) + -- fun_as_deftype: `%%`($fun_tag(z, x).TYPE_taginst, var_1) + -- fun_add_exninst: `%%%`(z, [exn], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:309.1-310.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), [])) + rule local_set{z : state, v_val : val, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_val(v_val) `LOCAL.SET`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [$instr_val(v_val) `LOCAL.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_local(z, x, v_val), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_local: `%%%%`(z, x, v_val, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:322.1-323.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), [])) + rule global_set{z : state, v_val : val, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_val(v_val) `GLOBAL.SET`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [$instr_val(v_val) `GLOBAL.SET`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_global(z, x, v_val), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_global: `%%%%`(z, x, v_val, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:336.1-338.33 rule table_set_oob{z : state, at : addrtype, i : num_, v_ref : ref, x : idx}: @@ -15122,32 +18544,37 @@ relation Step: `%~>%`(config, config) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_table(z, x).REFS_tableinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:340.1-342.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) =/= ?()) + rule table_set_val{z : state, at : addrtype, i : num_, v_ref : ref, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) $instr_ref(v_ref) `TABLE.SET`_instr(x)]), `%;%`_config(var_0, [])) -- 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), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- if ($proj_num__0(i) =/= ?()) -- if ($proj_uN_0(!($proj_num__0(i))).0 < |$fun_table(z, x).REFS_tableinst|) + -- fun_with_table: `%%%%%`(z, x, $proj_uN_0(!($proj_num__0(i))).0, v_ref, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:351.1-354.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|)))])) + rule table_grow_succeed{z : state, v_ref : ref, at : addrtype, v_n : n, x : idx, ti : tableinst, var_1 : tableinst?, var_0 : state}: + `%~>%`(`%;%`_config(z, [$instr_ref(v_ref) CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `TABLE.GROW`_instr(x)]), `%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$fun_table(z, x).REFS_tableinst|)))])) -- 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|)))])) - -- if ($growtable($fun_table(z, x), v_n, v_ref) =/= ?()) - -- if (ti = !($growtable($fun_table(z, x), v_n, v_ref))) + -- wf_config: `%`(`%;%`_config(var_0, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(|$fun_table(z, x).REFS_tableinst|)))])) + -- if (var_1 =/= ?()) + -- if (ti = !(var_1)) + -- fun_growtable: `%%%%`($fun_table(z, x), v_n, v_ref, var_1) + -- fun_with_tableinst: `%%%%`(z, x, ti, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:356.1-357.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)))))])) + rule table_grow_fail{z : state, v_ref : ref, at : addrtype, v_n : n, x : idx, var_0 : nat}: + `%~>%`(`%;%`_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(var_0)))])) -- 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)))))])) + -- 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:417.1-418.51 - rule elem_drop{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config($with_elem(z, x, []), [])) + rule elem_drop{z : state, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [`ELEM.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_elem(z, x, []), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_elem: `%%%%`(z, x, [], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:501.1-504.60 rule store_num_oob{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg}: @@ -15158,12 +18585,13 @@ relation Step: `%~>%`(config, config) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:506.1-510.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) =/= ?()) + rule store_num_val{z : state, at : addrtype, i : num_, nt : numtype, c : num_, x : idx, ao : memarg, b_lst : byte*, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) CONST_instr(nt, c) STORE_instr(nt, ?(), x, ao)]), `%;%`_config(var_0, [])) -- 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_config: `%`(`%;%`_config(var_0, [])) -- if (b_lst = $nbytes_(nt, c)) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:512.1-515.52 rule store_pack_oob{z : state, at : addrtype, i : num_, v_Inn : Inn, c : num_, v_n : n, x : idx, ao : memarg}: @@ -15174,13 +18602,14 @@ relation Step: `%~>%`(config, config) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:517.1-521.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) =/= ?()) + 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*, var_0 : state}: + `%~>%`(`%;%`_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(var_0, [])) -- 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), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) -- if ($proj_num__0(c) =/= ?()) -- if (b_lst = $ibytes_(v_n, $wrap__($size($numtype_addrtype(v_Inn)), v_n, !($proj_num__0(c))))) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:523.1-526.63 rule vstore_oob{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg}: @@ -15191,12 +18620,13 @@ relation Step: `%~>%`(config, config) -- 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|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:528.1-531.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) =/= ?()) + rule vstore_val{z : state, at : addrtype, i : num_, c : vec_, x : idx, ao : memarg, b_lst : byte*, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), i) VCONST_instr(V128_vectype, c) VSTORE_instr(V128_vectype, x, ao)]), `%;%`_config(var_0, [])) -- 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_config: `%`(`%;%`_config(var_0, [])) -- if (b_lst = $vbytes_(V128_vectype, c)) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:534.1-537.50 rule vstore_lane_oob{z : state, at : addrtype, i : num_, c : vec_, v_N : N, x : idx, ao : memarg, j : laneidx}: @@ -15207,49 +18637,56 @@ relation Step: `%~>%`(config, config) -- if ((($proj_uN_0(!($proj_num__0(i))).0 + $proj_uN_0(ao.OFFSET_memarg).0) + v_N) > |$fun_mem(z, x).BYTES_meminst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:539.1-544.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) =/= ?()) + 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, var_0 : state}: + `%~>%`(`%;%`_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(var_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_config: `%`(`%;%`_config(var_0, [])) -- 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)|) -- 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 (v_N = $jsize(v_Jnn)) -- if ((v_M : nat <:> rat) = ((128 : nat <:> rat) / (v_N : nat <:> rat))) -- 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))) + -- if ($proj_num__0(i) =/= ?()) + -- fun_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, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:553.1-556.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))))])) + rule memory_grow_succeed{z : state, at : addrtype, v_n : n, x : idx, mi : meminst, var_1 : meminst?, var_0 : state}: + `%~>%`(`%;%`_config(z, [CONST_instr($numtype_addrtype(at), mk_num__0_num_(at, `%`_uN(v_n))) `MEMORY.GROW`_instr(x)]), `%;%`_config(var_0, [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))))])) -- 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))))])) - -- if ($growmem($fun_mem(z, x), v_n) =/= ?()) - -- if (mi = !($growmem($fun_mem(z, x), v_n))) + -- wf_config: `%`(`%;%`_config(var_0, [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 (var_1 =/= ?()) + -- if (mi = !(var_1)) + -- fun_growmem: `%%%`($fun_mem(z, x), v_n, var_1) + -- fun_with_meminst: `%%%%`(z, x, mi, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:558.1-559.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)))))])) + rule memory_grow_fail{z : state, at : addrtype, v_n : n, x : idx, var_0 : nat}: + `%~>%`(`%;%`_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(var_0)))])) -- 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)))))])) + -- 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:619.1-620.51 - rule data_drop{z : state, x : idx}: - `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config($with_data(z, x, []), [])) + rule data_drop{z : state, x : idx, var_0 : state}: + `%~>%`(`%;%`_config(z, [`DATA.DROP`_instr(x)]), `%;%`_config(var_0, [])) -- wf_config: `%`(`%;%`_config(z, [`DATA.DROP`_instr(x)])) - -- wf_config: `%`(`%;%`_config($with_data(z, x, []), [])) + -- wf_config: `%`(`%;%`_config(var_0, [])) + -- fun_with_data: `%%%%`(z, x, [], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:700.1-704.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)])) + rule struct_new{z : state, v_n : n, val_lst : val*, x : idx, si : structinst, a : addr, mut_opt_lst : mut?*, zt_lst : storagetype*, var_1_lst : fieldval?*, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`STRUCT.NEW`_instr(x)]), `%;%`_config(var_0, [`REF.STRUCT_ADDR`_instr(a)])) -- 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_config: `%`(`%;%`_config(var_0, [`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: `%`({TYPE $fun_type(z, x), FIELDS !($packfield_(zt, v_val))^v_n{v_val <- val_lst, zt <- zt_lst}}) + -- (if (var_1 =/= ?()))^v_n{var_1 <- var_1_lst} + -- wf_structinst: `%`({TYPE $fun_type(z, x), FIELDS !(var_1)^v_n{var_1 <- var_1_lst}}) -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)^v_n{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- if (a = |$fun_structinst(z)|) - -- if (si = {TYPE $fun_type(z, x), FIELDS !($packfield_(zt, v_val))^v_n{v_val <- val_lst, zt <- zt_lst}}) + -- if (si = {TYPE $fun_type(z, x), FIELDS !(var_1)^v_n{var_1 <- var_1_lst}}) + -- (fun_packfield_: `%%%`(zt, v_val, var_1))^v_n{var_1 <- var_1_lst, v_val <- val_lst, zt <- zt_lst} + -- fun_add_structinst: `%%%`(z, [si], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:721.1-722.55 rule struct_set_null{z : state, v_val : val, x : idx, i : fieldidx}: @@ -15258,25 +18695,29 @@ relation Step: `%~>%`(config, config) -- wf_config: `%`(`%;%`_config(z, [TRAP_instr])) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:724.1-727.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))), [])) - -- if ($packfield_(zt_lst[$proj_uN_0(i).0], v_val) =/= ?()) - -- if ($proj_uN_0(i).0 < |zt_lst|) + rule struct_set_struct{z : state, a : addr, v_val : val, x : idx, i : fieldidx, zt_lst : storagetype*, mut_opt_lst : mut?*, var_1 : fieldval?, var_0 : state}: + `%~>%`(`%;%`_config(z, [`REF.STRUCT_ADDR`_instr(a) $instr_val(v_val) `STRUCT.SET`_instr(x, i)]), `%;%`_config(var_0, [])) -- 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_config: `%`(`%;%`_config(var_0, [])) -- wf_comptype: `%`(STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) -- Expand: `%~~%`($fun_type(z, x), STRUCT_comptype(`%`_list(`%%`_fieldtype(mut_opt, zt)*{mut_opt <- mut_opt_lst, zt <- zt_lst}))) + -- if ($proj_uN_0(i).0 < |zt_lst|) + -- fun_packfield_: `%%%`(zt_lst[$proj_uN_0(i).0], v_val, var_1) + -- if (var_1 =/= ?()) + -- fun_with_struct: `%%%%%`(z, a, $proj_uN_0(i).0, !(var_1), var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:740.1-745.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)])) + rule array_new_fixed{z : state, v_n : n, val_lst : val*, x : idx, ai : arrayinst, a : addr, mut_opt : mut?, zt : storagetype, var_1_lst : fieldval?*, var_0 : state}: + `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))]), `%;%`_config(var_0, [`REF.ARRAY_ADDR`_instr(a)])) -- 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_config: `%`(`%;%`_config(var_0, [`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: `%`({TYPE $fun_type(z, x), FIELDS !($packfield_(zt, v_val))^v_n{v_val <- val_lst}}) + -- (if (var_1 =/= ?()))^v_n{var_1 <- var_1_lst} + -- wf_arrayinst: `%`({TYPE $fun_type(z, x), FIELDS !(var_1)^v_n{var_1 <- var_1_lst}}) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_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}})) + -- if ((a = |$fun_arrayinst(z)|) /\ (ai = {TYPE $fun_type(z, x), FIELDS !(var_1)^v_n{var_1 <- var_1_lst}})) + -- (fun_packfield_: `%%%`(zt, v_val, var_1))^v_n{var_1 <- var_1_lst, v_val <- val_lst} + -- fun_add_arrayinst: `%%%`(z, [ai], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:785.1-786.66 rule array_set_null{z : state, i : num_, v_val : val, x : idx}: @@ -15294,14 +18735,16 @@ relation Step: `%~>%`(config, config) -- if ($proj_uN_0(!($proj_num__0(i))).0 >= |$fun_arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:792.1-795.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))), [])) - -- if ($proj_num__0(i) =/= ?()) - -- if ($packfield_(zt, v_val) =/= ?()) + rule array_set_array{z : state, a : addr, i : num_, v_val : val, x : idx, zt : storagetype, mut_opt : mut?, var_1 : fieldval?, var_0 : state}: + `%~>%`(`%;%`_config(z, [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) $instr_val(v_val) `ARRAY.SET`_instr(x)]), `%;%`_config(var_0, [])) -- 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_config: `%`(`%;%`_config(var_0, [])) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) + -- fun_packfield_: `%%%`(zt, v_val, var_1) + -- if ($proj_num__0(i) =/= ?()) + -- if (var_1 =/= ?()) + -- fun_with_array: `%%%%%`(z, a, $proj_uN_0(!($proj_num__0(i))).0, !(var_1), var_0) } ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec @@ -15336,23 +18779,30 @@ 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(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*, deftype_lst : deftype*, v_rectype : rectype, x : uN}(type'_lst ++ [v_type]) = deftype'_lst ++ deftype_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*, deftype_lst : deftype*, v_rectype : rectype, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: + `%%`(type'_lst ++ [v_type], deftype'_lst ++ deftype_lst) + -- 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) -- wf_uN: `%%`(32, x) - -- if (deftype'_lst = $alloctypes(type'_lst)) + -- if (deftype'_lst = var_0) -- if (v_type = TYPE_type(v_rectype)) - -- 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|) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctag(v_store : store, v_tagtype : tagtype) : (store, tagaddr) +relation fun_alloctag: `%%%`(store, tagtype, (store, tagaddr)) ;; ../../../../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|) + 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|)) -- wf_store: `%`({TAGS [v_taginst], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_taginst: `%`({TYPE v_tagtype}) -- if (v_taginst = {TYPE v_tagtype}) @@ -15360,22 +18810,28 @@ def $alloctag(v_store : store, v_tagtype : tagtype) : (store, tagaddr) ;; ../../../../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_2 : store, ja : nat, ja'_lst : tagaddr*, s_1 : store}(s, [v_tagtype] ++ tagtype'_lst) = (s_2, [ja] ++ ja'_lst) +;; ../../../../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*, s_2 : store, ja : nat, ja'_lst : tagaddr*, s_1 : store, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: + `%%%`(s, [v_tagtype] ++ tagtype'_lst, (s_2, [ja] ++ ja'_lst)) + -- fun_alloctags: `%%%`(s_1, tagtype'_lst, var_1) + -- fun_alloctag: `%%%`(s, v_tagtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ja) = $alloctag(s, v_tagtype)) - -- if ((s_2, ja'_lst) = $alloctags(s_1, tagtype'_lst)) + -- if ((s_1, ja) = var_0) + -- if ((s_2, ja'_lst) = var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocglobal(v_store : store, v_globaltype : globaltype, v_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, 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|) + 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|)) -- wf_store: `%`({TAGS [], GLOBALS [v_globalinst], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_globalinst: `%`({TYPE v_globaltype, VALUE v_val}) -- if (v_globalinst = {TYPE v_globaltype, VALUE v_val}) @@ -15383,22 +18839,28 @@ def $allocglobal(v_store : store, v_globaltype : globaltype, v_val : val) : (sto ;; ../../../../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_2 : store, ga : nat, ga'_lst : globaladdr*, s_1 : store}(s, [v_globaltype] ++ globaltype'_lst, [v_val] ++ val'_lst) = (s_2, [ga] ++ ga'_lst) +;; ../../../../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*, s_2 : store, ga : nat, ga'_lst : globaladdr*, s_1 : store, var_1 : (store, globaladdr*), var_0 : (store, globaladdr)}: + `%%%%`(s, [v_globaltype] ++ globaltype'_lst, [v_val] ++ val'_lst, (s_2, [ga] ++ ga'_lst)) + -- fun_allocglobals: `%%%%`(s_1, globaltype'_lst, val'_lst, var_1) + -- fun_allocglobal: `%%%%`(s, v_globaltype, v_val, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ga) = $allocglobal(s, v_globaltype, v_val)) - -- if ((s_2, ga'_lst) = $allocglobals(s_1, globaltype'_lst, val'_lst)) + -- if ((s_1, ga) = var_0) + -- if ((s_2, ga'_lst) = var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocmem(v_store : store, v_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_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|) + rule fun_allocmem_case_0{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|)) -- 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)){}}) -- if (v_meminst = {TYPE `%%PAGE`_memtype(at, `[%..%]`_limits(i, j_opt)), BYTES `%`_byte(0)^($proj_uN_0(i).0 * (64 * $Ki)){}}) @@ -15406,22 +18868,28 @@ def $allocmem(v_store : store, v_memtype : memtype) : (store, memaddr) ;; ../../../../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_2 : store, ma : nat, ma'_lst : memaddr*, s_1 : store}(s, [v_memtype] ++ memtype'_lst) = (s_2, [ma] ++ ma'_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*, s_2 : store, ma : nat, ma'_lst : memaddr*, s_1 : store, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: + `%%%`(s, [v_memtype] ++ memtype'_lst, (s_2, [ma] ++ ma'_lst)) + -- fun_allocmems: `%%%`(s_1, memtype'_lst, var_1) + -- fun_allocmem: `%%%`(s, v_memtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ma) = $allocmem(s, v_memtype)) - -- if ((s_2, ma'_lst) = $allocmems(s_1, memtype'_lst)) + -- if ((s_1, ma) = var_0) + -- if ((s_2, ma'_lst) = var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $alloctable(v_store : store, v_tabletype : tabletype, v_ref : ref) : (store, tableaddr) +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_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|) + rule fun_alloctable_case_0{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|)) -- 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{}}) -- if (v_tableinst = {TYPE `%%%`_tabletype(at, `[%..%]`_limits(i, j_opt), rt), REFS v_ref^$proj_uN_0(i).0{}}) @@ -15429,22 +18897,28 @@ def $alloctable(v_store : store, v_tabletype : tabletype, v_ref : ref) : (store, ;; ../../../../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_2 : store, ta : nat, ta'_lst : tableaddr*, s_1 : store}(s, [v_tabletype] ++ tabletype'_lst, [v_ref] ++ ref'_lst) = (s_2, [ta] ++ ta'_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*, s_2 : store, ta : nat, ta'_lst : tableaddr*, s_1 : store, var_1 : (store, tableaddr*), var_0 : (store, tableaddr)}: + `%%%%`(s, [v_tabletype] ++ tabletype'_lst, [v_ref] ++ ref'_lst, (s_2, [ta] ++ ta'_lst)) + -- fun_alloctables: `%%%%`(s_1, tabletype'_lst, ref'_lst, var_1) + -- fun_alloctable: `%%%%`(s, v_tabletype, v_ref, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ta) = $alloctable(s, v_tabletype, v_ref)) - -- if ((s_2, ta'_lst) = $alloctables(s_1, tabletype'_lst, ref'_lst)) + -- if ((s_1, ta) = var_0) + -- if ((s_2, ta'_lst) = var_1) } ;; ../../../../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|)) -- 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}) -- if (v_funcinst = {TYPE v_deftype, MODULE v_moduleinst, CODE v_funccode}) @@ -15452,22 +18926,28 @@ def $allocfunc(v_store : store, v_deftype : deftype, v_funccode : funccode, v_mo ;; ../../../../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_2 : store, fa : nat, fa'_lst : funcaddr*, s_1 : store}(s, [dt] ++ dt'_lst, [v_funccode] ++ funccode'_lst, [v_moduleinst] ++ moduleinst'_lst) = (s_2, [fa] ++ fa'_lst) +;; ../../../../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*, s_2 : store, fa : nat, fa'_lst : funcaddr*, s_1 : store, 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)) + -- fun_allocfuncs: `%%%%%`(s_1, dt'_lst, funccode'_lst, moduleinst'_lst, var_1) + -- fun_allocfunc: `%%%%%`(s, dt, v_funccode, v_moduleinst, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, fa) = $allocfunc(s, dt, v_funccode, v_moduleinst)) - -- if ((s_2, fa'_lst) = $allocfuncs(s_1, dt'_lst, funccode'_lst, moduleinst'_lst)) + -- if ((s_1, fa) = var_0) + -- if ((s_2, fa'_lst) = var_1) } ;; ../../../../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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [v_datainst], ELEMS [], STRUCTS [], ARRAYS [], EXNS []}) -- wf_datainst: `%`({BYTES byte_lst}) -- if (v_datainst = {BYTES byte_lst}) @@ -15475,22 +18955,28 @@ def $allocdata(v_store : store, v_datatype : datatype, var_0 : byte*) : (store, ;; ../../../../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_2 : store, da : nat, da'_lst : dataaddr*, s_1 : store}(s, [ok] ++ ok'_lst, [b_lst] ++ b'_lst_lst) = (s_2, [da] ++ da'_lst) +;; ../../../../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**, s_2 : store, da : nat, da'_lst : dataaddr*, s_1 : store, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: + `%%%%`(s, [ok] ++ ok'_lst, [b_lst] ++ b'_lst_lst, (s_2, [da] ++ da'_lst)) + -- fun_allocdatas: `%%%%`(s_1, ok'_lst, b'_lst_lst, var_1) + -- fun_allocdata: `%%%%`(s, ok, b_lst, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, da) = $allocdata(s, ok, b_lst)) - -- if ((s_2, da'_lst) = $allocdatas(s_1, ok'_lst, b'_lst_lst)) + -- if ((s_1, da) = var_0) + -- if ((s_2, da'_lst) = var_1) } ;; ../../../../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|)) -- wf_store: `%`({TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [v_eleminst], STRUCTS [], ARRAYS [], EXNS []}) -- wf_eleminst: `%`({TYPE v_elemtype, REFS ref_lst}) -- if (v_eleminst = {TYPE v_elemtype, REFS ref_lst}) @@ -15498,45 +18984,88 @@ def $allocelem(v_store : store, v_elemtype : elemtype, var_0 : ref*) : (store, e ;; ../../../../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_2 : store, ea : nat, ea'_lst : elemaddr*, s_1 : store}(s, [rt] ++ rt'_lst, [ref_lst] ++ ref'_lst_lst) = (s_2, [ea] ++ ea'_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**, s_2 : store, ea : nat, ea'_lst : elemaddr*, s_1 : store, var_1 : (store, elemaddr*), var_0 : (store, elemaddr)}: + `%%%%`(s, [rt] ++ rt'_lst, [ref_lst] ++ ref'_lst_lst, (s_2, [ea] ++ ea'_lst)) + -- fun_allocelems: `%%%%`(s_1, rt'_lst, ref'_lst_lst, var_1) + -- fun_allocelem: `%%%%`(s, rt, ref_lst, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) - -- if ((s_1, ea) = $allocelem(s, rt, ref_lst)) - -- if ((s_2, ea'_lst) = $allocelems(s_1, rt'_lst, ref'_lst_lst)) + -- if ((s_1, ea) = var_0) + -- if ((s_2, ea'_lst) = var_1) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $allocexport(v_moduleinst : moduleinst, v_export : export) : exportinst +relation fun_allocexport: `%%%`(moduleinst, 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])} + rule fun_allocexport_case_0{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])}) + -- if ($proj_uN_0(x).0 < |v_moduleinst.TAGS_moduleinst|) -- 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])} + rule fun_allocexport_case_1{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])}) + -- if ($proj_uN_0(x).0 < |v_moduleinst.GLOBALS_moduleinst|) -- 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])} + rule fun_allocexport_case_2{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])}) + -- if ($proj_uN_0(x).0 < |v_moduleinst.MEMS_moduleinst|) -- 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])} + rule fun_allocexport_case_3{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])}) + -- if ($proj_uN_0(x).0 < |v_moduleinst.TABLES_moduleinst|) -- 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])} + rule fun_allocexport_case_4{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])}) + -- if ($proj_uN_0(x).0 < |v_moduleinst.FUNCS_moduleinst|) -- 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 -def $allocexports(v_moduleinst : moduleinst, var_0 : export*) : exportinst* +relation fun_allocexports: `%%%`(moduleinst, export*, exportinst*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - def $allocexports{v_moduleinst : moduleinst, export_lst : export*}(v_moduleinst, export_lst) = $allocexport(v_moduleinst, v_export)*{v_export <- export_lst} + rule fun_allocexports_case_0{v_moduleinst : moduleinst, export_lst : export*, var_0_lst : exportinst*}: + `%%%`(v_moduleinst, export_lst, var_0_lst) + -- if (|var_0_lst| = |export_lst|) + -- (fun_allocexport: `%%%`(v_moduleinst, v_export, var_0))*{var_0 <- var_0_lst, 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 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, 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*, 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**, aa_I_lst : tagaddr*, ga_I_lst : globaladdr*, ma_I_lst : memaddr*, ta_I_lst : tableaddr*, fa_I_lst : funcaddr*, dt_lst : deftype*, fa_lst : nat*, s_1 : store, aa_lst : tagaddr*, s_2 : store, ga_lst : globaladdr*, s_3 : store, ma_lst : memaddr*, s_4 : store, ta_lst : tableaddr*, s_5 : store, da_lst : dataaddr*, s_6 : store, ea_lst : elemaddr*, xi_lst : exportinst*}(s, v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst) = (s_7, v_moduleinst) + 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, 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*, 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**, aa_I_lst : tagaddr*, ga_I_lst : globaladdr*, ma_I_lst : memaddr*, ta_I_lst : tableaddr*, fa_I_lst : funcaddr*, dt_lst : deftype*, fa_lst : nat*, s_1 : store, aa_lst : tagaddr*, s_2 : store, ga_lst : globaladdr*, s_3 : store, ma_lst : memaddr*, s_4 : store, ta_lst : tableaddr*, s_5 : store, da_lst : dataaddr*, s_6 : store, ea_lst : elemaddr*, xi_lst : exportinst*, var_13 : exportinst*, var_12 : (store, funcaddr*), var_11_lst : elemtype*, var_10 : (store, elemaddr*), var_9 : (store, dataaddr*), var_8_lst : tabletype*, var_7 : (store, tableaddr*), var_6_lst : memtype*, var_5 : (store, memaddr*), var_4_lst : globaltype*, var_3 : (store, globaladdr*), var_2_lst : tagtype*, var_1 : (store, tagaddr*), var_0 : deftype*}: + `%%%%%%%`(s, v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst, (s_7, v_moduleinst)) + -- fun_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, var_13) + -- (if ($proj_uN_0(x#4).0 < |dt_lst|))*{x#4 <- x_lst} + -- fun_allocfuncs: `%%%%%`(s_6, dt_lst[$proj_uN_0(x#4).0]*{x#4 <- x_lst}, FUNC_funccode(x#5, local_lst#86, expr_F#3)*{expr_F#3 <- expr_F_lst, local_lst#86 <- local_lst_lst, x#5 <- x_lst}, v_moduleinst^|func_lst|{}, var_12) + -- if (|var_11_lst| = |elemtype_lst|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- dt_lst}, var_11))*{var_11 <- var_11_lst, elemtype#3 <- elemtype_lst} + -- fun_allocelems: `%%%%`(s_5, var_11_lst, ref_E_lst_lst, var_10) + -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data_lst|{}, byte_lst_lst, var_9) + -- if (|var_8_lst| = |tabletype_lst|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- dt_lst}, var_8))*{var_8 <- var_8_lst, tabletype#160 <- tabletype_lst} + -- fun_alloctables: `%%%%`(s_3, var_8_lst, ref_T_lst, var_7) + -- if (|var_6_lst| = |memtype_lst|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- dt_lst}, var_6))*{var_6 <- var_6_lst, memtype#126 <- memtype_lst} + -- fun_allocmems: `%%%`(s_2, var_6_lst, var_5) + -- if (|var_4_lst| = |globaltype_lst|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- dt_lst}, var_4))*{var_4 <- var_4_lst, globaltype#126 <- globaltype_lst} + -- fun_allocglobals: `%%%%`(s_1, var_4_lst, val_G_lst, var_3) + -- if (|var_2_lst| = |tagtype_lst|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- dt_lst}, var_2))*{var_2 <- var_2_lst, tagtype#82 <- tagtype_lst} + -- fun_alloctags: `%%%`(s, var_2_lst, var_1) + -- fun_alloctypes: `%%`(type_lst, var_0) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(v_moduleinst) -- wf_store: `%`(s_1) @@ -15547,11 +19076,18 @@ def $allocmodule(v_store : store, v_module : module, var_0 : externaddr*, var_1 -- wf_store: `%`(s_6) -- 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#78)))*{tagtype#78 <- tagtype_lst} + -- if (|expr_G_lst| = |globaltype_lst|) -- (wf_global: `%`(GLOBAL_global(globaltype#122, expr_G#1)))*{expr_G#1 <- expr_G_lst, globaltype#122 <- globaltype_lst} -- (wf_mem: `%`(MEMORY_mem(memtype#122)))*{memtype#122 <- memtype_lst} + -- if (|expr_T_lst| = |tabletype_lst|) -- (wf_table: `%`(TABLE_table(tabletype#156, expr_T#1)))*{expr_T#1 <- expr_T_lst, tabletype#156 <- tabletype_lst} + -- if (|expr_F_lst| = |local_lst_lst|) + -- if (|expr_F_lst| = |x_lst|) -- (wf_func: `%`(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 (|byte_lst_lst| = |datamode_lst|) -- (wf_data: `%`(DATA_data(byte_lst#110, datamode#110)))*{byte_lst#110 <- byte_lst_lst, datamode#110 <- datamode_lst} + -- if (|elemmode_lst| = |elemtype_lst|) + -- if (|elemmode_lst| = |expr_E_lst_lst|) -- (wf_elem: `%`(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} -- 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}) @@ -15568,38 +19104,46 @@ def $allocmodule(v_store : store, v_module : module, var_0 : externaddr*, var_1 -- if (ma_I_lst = $memsxa(externaddr_lst)) -- if (ta_I_lst = $tablesxa(externaddr_lst)) -- if (fa_I_lst = $funcsxa(externaddr_lst)) - -- if (dt_lst = $alloctypes(type_lst)) + -- if (dt_lst = var_0) -- if (fa_lst = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func_lst|){}) - -- if ((s_1, aa_lst) = $alloctags(s, $subst_all_tagtype(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- dt_lst})*{tagtype#82 <- tagtype_lst})) - -- if ((s_2, ga_lst) = $allocglobals(s_1, $subst_all_globaltype(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- dt_lst})*{globaltype#126 <- globaltype_lst}, val_G_lst)) - -- if ((s_3, ma_lst) = $allocmems(s_2, $subst_all_memtype(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- dt_lst})*{memtype#126 <- memtype_lst})) - -- if ((s_4, ta_lst) = $alloctables(s_3, $subst_all_tabletype(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- dt_lst})*{tabletype#160 <- tabletype_lst}, ref_T_lst)) - -- if ((s_5, da_lst) = $allocdatas(s_4, OK_datatype^|data_lst|{}, byte_lst_lst)) - -- if ((s_6, ea_lst) = $allocelems(s_5, $subst_all_reftype(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- dt_lst})*{elemtype#3 <- elemtype_lst}, ref_E_lst_lst)) - -- if ((s_7, fa_lst) = $allocfuncs(s_6, dt_lst[$proj_uN_0(x#4).0]*{x#4 <- x_lst}, FUNC_funccode(x#5, local_lst#86, expr_F#3)*{expr_F#3 <- expr_F_lst, local_lst#86 <- local_lst_lst, x#5 <- x_lst}, v_moduleinst^|func_lst|{})) - -- 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 ((s_1, aa_lst) = var_1) + -- if ((s_2, ga_lst) = var_3) + -- if ((s_3, ma_lst) = var_5) + -- if ((s_4, ta_lst) = var_7) + -- if ((s_5, da_lst) = var_9) + -- if ((s_6, ea_lst) = var_10) + -- if ((s_7, fa_lst) = var_12) + -- if (xi_lst = var_13) -- 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}) ;; ../../../../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), []) + ;; ../../../../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)] + 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, `%`_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)) ;; ../../../../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 - def $runelem_{x : uN, rt : reftype, v_n : nat, e_lst : expr*}(x, ELEM_elem(rt, e_lst, PASSIVE_elemmode)) = [] + rule fun_runelem__case_0{x : uN, rt : reftype, v_n : nat, e_lst : expr*}: + `%%%`(x, ELEM_elem(rt, e_lst, PASSIVE_elemmode), []) + ;; ../../../../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)] + 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)]) -- wf_instr: `%`(`ELEM.DROP`_instr(x)) + ;; ../../../../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)] + 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, `%`_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)) @@ -15608,46 +19152,60 @@ def $runelem_(v_elemidx : elemidx, v_elem : elem) : instr* ;; ../../../../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*, z'' : state, v_ref : ref, ref'_lst : 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*, z'' : state, v_ref : ref, ref'_lst : ref*, z' : state, var_0 : (state, ref*)}: + `%%%`(z, [v_expr] ++ expr'_lst, (z'', [v_ref] ++ ref'_lst)) + -- fun_evalexprs: `%%%`(z', expr'_lst, var_0) -- wf_state: `%`(z'') -- wf_ref: `%`(v_ref) -- (wf_ref: `%`(ref'#5))*{ref'#5 <- ref'_lst} -- wf_state: `%`(z') -- Eval_expr: `%;%~>*%;%`(z, v_expr, z', [$val_ref(v_ref)]) - -- if ((z'', ref'_lst) = $evalexprs(z', expr'_lst)) + -- if ((z'', ref'_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'' : state, ref_lst : ref*, ref'_lst_lst : ref**, z' : state}(z, [expr_lst] ++ expr'_lst_lst) = (z'', [ref_lst] ++ ref'_lst_lst) +;; ../../../../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**, z'' : state, ref_lst : ref*, ref'_lst_lst : ref**, z' : state, var_1 : (state, ref**), var_0 : (state, ref*)}: + `%%%`(z, [expr_lst] ++ expr'_lst_lst, (z'', [ref_lst] ++ ref'_lst_lst)) + -- fun_evalexprss: `%%%`(z', expr'_lst_lst, var_1) + -- fun_evalexprs: `%%%`(z, expr_lst, var_0) -- wf_state: `%`(z'') -- (wf_ref: `%`(ref#6))*{ref#6 <- ref_lst} -- (wf_ref: `%`(ref'#7))*{ref'#7 <- ref'_lst#3}*{ref'_lst#3 <- ref'_lst_lst} -- wf_state: `%`(z') - -- if ((z', ref_lst) = $evalexprs(z, expr_lst)) - -- if ((z'', ref'_lst_lst) = $evalexprss(z', expr'_lst_lst)) + -- if ((z', ref_lst) = var_0) + -- if ((z'', ref'_lst_lst) = 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*, z'' : state, v_val : val, val'_lst : val*, z' : state, s : store, f : frame, s' : store, a : nat}(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*, z'' : state, v_val : val, val'_lst : val*, z' : state, s : store, f : frame, s' : store, a : nat, var_1 : (state, val*), var_0 : (store, globaladdr)}: + `%%%%`(z, [gt] ++ gt'_lst, [v_expr] ++ expr'_lst, (z'', [v_val] ++ val'_lst)) + -- fun_evalglobals: `%%%%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'_lst, expr'_lst, var_1) + -- fun_allocglobal: `%%%%`(s, gt, v_val, var_0) -- wf_state: `%`(z'') -- wf_val: `%`(v_val) -- (wf_val: `%`(val'#3))*{val'#3 <- val'_lst} @@ -15656,14 +19214,25 @@ def $evalglobals(v_state : state, var_0 : globaltype*, var_1 : expr*) : (state, -- wf_state: `%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]])) -- Eval_expr: `%;%~>*%;%`(z, v_expr, z', [v_val]) -- if (z' = `%;%`_state(s, f)) - -- if ((s', a) = $allocglobal(s, gt, v_val)) - -- if ((z'', val'_lst) = $evalglobals(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'_lst, expr'_lst)) + -- if ((s', a) = var_0) + -- if ((z'', val'_lst) = var_1) } ;; ../../../../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*, s'''' : store, v_moduleinst : moduleinst, instr_E_lst : instr*, instr_D_lst : instr*, instr_S_opt : instr?, xt_I_lst : externtype*, xt_E_lst : externtype*, 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*, 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, z' : state, val_G_lst : val*, z'' : state, ref_T_lst : ref*, z''' : state, ref_E_lst_lst : ref**, s''' : store, f : frame, 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)) + rule fun_instantiate_case_0{s : store, v_module : module, externaddr_lst : externaddr*, s'''' : store, v_moduleinst : moduleinst, instr_E_lst : instr*, instr_D_lst : instr*, instr_S_opt : instr?, xt_I_lst : externtype*, xt_E_lst : externtype*, 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*, 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, z' : state, val_G_lst : val*, z'' : state, ref_T_lst : ref*, z''' : state, ref_E_lst_lst : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, var_7_lst : instr**, var_6_lst : instr**, var_5 : (store, moduleinst), var_4 : (state, ref**), var_3 : (state, ref*), var_2 : (state, val*), var_1 : deftype*, var_0 : deftype*}: + `%%%%`(s, v_module, externaddr_lst, `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE v_moduleinst}), instr_E_lst ++ instr_D_lst ++ lift(instr_S_opt))) + -- (if (i_E#2 < |elem_lst|))^(i_E#2<|elem_lst|){} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem_lst[i_E#2], var_7))^(i_E#2<|elem_lst|){var_7 <- var_7_lst} + -- (if (i_D#2 < |data_lst|))^(i_D#2<|data_lst|){} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data_lst[i_D#2], var_6))^(i_D#2<|data_lst|){var_6 <- var_6_lst} + -- fun_allocmodule: `%%%%%%%`(s''', v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst, var_5) + -- fun_evalexprss: `%%%`(z'', expr_E_lst_lst, var_4) + -- fun_evalexprs: `%%%`(z', expr_T_lst, var_3) + -- fun_evalglobals: `%%%%`(z, globaltype_lst, expr_G_lst, var_2) + -- fun_alloctypes: `%%`(type_lst, var_1) + -- fun_alloctypes: `%%`(type_lst, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') -- (wf_val: `%`(val_G#3))*{val_G#3 <- val_G_lst} @@ -15674,18 +19243,24 @@ def $instantiate(v_store : store, v_module : module, var_0 : externaddr*) : conf -- 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))) + -- if (|expr_G_lst| = |globaltype_lst|) -- (wf_global: `%`(GLOBAL_global(globaltype#127, expr_G#3)))*{expr_G#3 <- expr_G_lst, globaltype#127 <- globaltype_lst} + -- if (|expr_T_lst| = |tabletype_lst|) -- (wf_table: `%`(TABLE_table(tabletype#161, expr_T#3)))*{expr_T#3 <- expr_T_lst, tabletype#161 <- tabletype_lst} + -- if (|byte_lst_lst| = |datamode_lst|) -- (wf_data: `%`(DATA_data(byte_lst#117, datamode#116)))*{byte_lst#117 <- byte_lst_lst, datamode#116 <- datamode_lst} + -- if (|elemmode_lst| = |expr_E_lst_lst|) + -- if (|elemmode_lst| = |reftype_lst|) -- (wf_elem: `%`(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} -- (wf_start: `%`(START_start(x#6)))?{x#6 <- x_opt} - -- wf_moduleinst: `%`({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 []}) + -- wf_moduleinst: `%`({TYPES var_0, 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 []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#1)))^(i_D#1<|data_lst|){} -- (wf_uN: `%%`(32, `%`_uN(i_E#1)))^(i_E#1<|elem_lst|){} -- (wf_instr: `%`(CALL_instr(x#7)))?{x#7 <- x_opt} -- Module_ok: `|-%:%`(v_module, `%->%`_moduletype(xt_I_lst, xt_E_lst)) + -- if (|externaddr_lst| = |xt_I_lst|) -- (Externaddr_ok: `%|-%:%`(s, externaddr#10, xt_I#3))*{externaddr#10 <- externaddr_lst, xt_I#3 <- xt_I_lst} -- if (v_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))) -- if (global_lst = GLOBAL_global(globaltype#129, expr_G#4)*{expr_G#4 <- expr_G_lst, globaltype#129 <- globaltype_lst}) @@ -15693,24 +19268,27 @@ def $instantiate(v_store : store, v_module : module, var_0 : externaddr*) : conf -- if (data_lst = DATA_data(byte_lst#119, datamode#118)*{byte_lst#119 <- byte_lst_lst, datamode#118 <- datamode_lst}) -- if (elem_lst = ELEM_elem(reftype#519, expr_E_lst#4, elemmode#239)*{elemmode#239 <- elemmode_lst, expr_E_lst#4 <- expr_E_lst_lst, reftype#519 <- reftype_lst}) -- if (start_opt = START_start(x#8)?{x#8 <- 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#3)^(i_F#3<|func_lst|){}, DATAS [], ELEMS [], EXPORTS []}) + -- if (moduleinst_0 = {TYPES var_1, 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 []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- if ((z', val_G_lst) = $evalglobals(z, globaltype_lst, expr_G_lst)) - -- if ((z'', ref_T_lst) = $evalexprs(z', expr_T_lst)) - -- if ((z''', ref_E_lst_lst) = $evalexprss(z'', expr_E_lst_lst)) + -- if ((z', val_G_lst) = var_2) + -- if ((z'', ref_T_lst) = var_3) + -- if ((z''', ref_E_lst_lst) = var_4) -- if (z''' = `%;%`_state(s''', f)) - -- if ((s'''', v_moduleinst) = $allocmodule(s''', v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst)) - -- if (instr_D_lst = $concat_(syntax instr, $rundata_(`%`_dataidx(i_D#2), data_lst[i_D#2])^(i_D#2<|data_lst|){})) - -- if (instr_E_lst = $concat_(syntax instr, $runelem_(`%`_elemidx(i_E#2), elem_lst[i_E#2])^(i_E#2<|elem_lst|){})) + -- if ((s'''', v_moduleinst) = var_5) + -- if (instr_D_lst = $concat_(syntax instr, var_6_lst)) + -- if (instr_E_lst = $concat_(syntax instr, var_7_lst)) -- if (instr_S_opt = CALL_instr(x#9)?{x#9 <- x_opt}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec -def $invoke(v_store : store, v_funcaddr : funcaddr, var_0 : val*) : config +relation fun_invoke: `%%%%`(store, funcaddr, 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))]) + 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, `%;%`_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))])) + -- if (v_funcaddr < |s.FUNCS_store|) -- wf_config: `%`(`%;%`_config(`%;%`_state(s, {LOCALS [], MODULE {TYPES [], TAGS [], GLOBALS [], MEMS [], TABLES [], FUNCS [], DATAS [], ELEMS [], EXPORTS []}}), $instr_val(val#2)*{val#2 <- 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))) -- Expand: `%~~%`(s.FUNCS_store[v_funcaddr].TYPE_funcinst, `FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst))) + -- if (|t_1_lst| = |val_lst|) -- (Val_ok: `%|-%:%`(s, val#3, t_1#8))*{t_1#8 <- t_1_lst, val#3 <- val_lst} ;; ../../../../specification/wasm-3.0/5.3-binary.instructions.spectec @@ -15771,13 +19349,17 @@ 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 []} +;; ../../../../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 []}) -- 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 + 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 @@ -16060,12 +19642,15 @@ def $exportsd(var_0 : decl*) : export* } ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec -def $ordered(var_0 : decl*) : bool +relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - def $ordered{decl_lst : decl*}(decl_lst) = true + rule fun_ordered_case_0{decl_lst : decl*}: + `%%`(decl_lst, true) -- if ($importsd(decl_lst) = []) + ;; ../../../../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*}: + `%%`(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) = []))) ;; ../../../../specification/wasm-3.0/7.0-soundness.contexts.spectec relation Context_ok: `|-%:OK`(context) @@ -16077,7 +19662,6 @@ relation Context_ok: `|-%:OK`(context) -- 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 [], 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(`%`_resulttype([t_1]), `%`_resulttype([t_2]))))*{t_1 <- t_1_lst, t_2 <- t_2_lst} @@ -16270,7 +19854,7 @@ 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_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*}: + 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, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), x_1_lst ++ x_2_lst, `%`_resulttype(t_3_lst))) -- wf_store: `%`(s) -- wf_context: `%`(C) @@ -16286,8 +19870,9 @@ relation Instrs_ok2: `%;%|-%:%`(store, context, instr*, instrtype) -- 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))) + -- if (var_0 =/= ?()) + -- Instrs_ok2: `%;%|-%:%`(s, !(var_0), instr_2_lst, `%->_%%`_instrtype(`%`_resulttype(t_2_lst), x_2_lst, `%`_resulttype(t_3_lst))) + -- fun_with_locals: `%%%%`(C, x_1_lst, `%%`_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}: @@ -16476,23 +20061,34 @@ relation ImmutReachable: `%>>_%%`(fieldval, store, fieldval) } ;; ../../../../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) -- wf_fieldval: `%`(fv_1) -- wf_store: `%`(s) -- wf_fieldval: `%`(fv_2) - -- if $fun_NotImmutReachable(fv_1, s, fv_2) + -- if var_0 + -- fun_NotImmutReachable: `%%%%`(fv_1, s, fv_2, var_0) ;; ../../../../specification/wasm-3.0/7.1-soundness.configurations.spectec relation Store_ok: `|-%:OK`(store) @@ -16895,7 +20491,8 @@ grammar BsN(v_N : N) : sN ;; ../../../../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) => `%`_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 @@ -16945,8 +20542,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{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 @@ -18433,10 +22031,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_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*{}} {`%`_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)) -- (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 @@ -18607,7 +22206,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))] @@ -18620,8 +22220,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_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 => `%`_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 @@ -18785,7 +22386,8 @@ 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) ;; ../../../../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) => `%`_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 { @@ -18844,10 +22446,12 @@ grammar TfNmag(v_N : N) : 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_(v_N)) + prod{var_0 : m} "nan" => NAN_fNmag(var_0) + -- fun_canon_: `%%`(v_N, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{v_n : n} {{"nan:0x"} {v_n:Thexnum}} => NAN_fNmag(v_n) - -- if ((1 <= v_n) /\ (v_n < (2 ^ !($signif(v_N))))) + prod{v_n : n, var_0 : nat?} {{"nan:0x"} {v_n:Thexnum}} => NAN_fNmag(v_n) + -- if ((1 <= v_n) /\ (v_n < (2 ^ !(var_0)))) + -- fun_signif: `%%`(v_N, var_0) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar TfN(v_N : N) : fN @@ -19115,7 +22719,8 @@ grammar Ttypedef_(v_I : I) : (subtype, idctxt) ;; ../../../../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(`%`_list(st_lst)), var_0) + -- fun_concat_idctxt: `%%`(I'_lst, var_0) ;; ../../../../specification/wasm-3.0/6.2-text.types.spectec grammar Taddrtype : addrtype @@ -20302,9 +23907,10 @@ grammar Tlocal_(v_I : I) : (local*, idctxt) ;; ../../../../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"} {?(`%`_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 +++ 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* @@ -20465,8 +24071,8 @@ 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_1 : bool, var_0 : idctxt} {{"("} {"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' = var_0) -- Idctxt_ok: `|-%:OK`(I') -- if (type_lst = $typesd(decl_lst)) -- if (import_lst = $importsd(decl_lst)) @@ -20479,7 +24085,9 @@ grammar Tmodule : module -- if (elem_lst = $elemsd(decl_lst)) -- if (lift(start_opt) = $startsd(decl_lst)) -- if (export_lst = $exportsd(decl_lst)) - -- if $ordered(decl_lst) + -- if var_1 + -- fun_ordered: `%%`(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)* diff --git a/spectec/test-middlend/test.spectec.exp b/spectec/test-middlend/test.spectec.exp index 1235cae41d..e34d0ac44e 100644 --- a/spectec/test-middlend/test.spectec.exp +++ b/spectec/test-middlend/test.spectec.exp @@ -229,7 +229,7 @@ def $t_totalize3(nat : nat) : nat? 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 uncase-removal... -== Running pass sideconditions... +== Running pass sub-expansion... ;; test.spectec relation HasSize: `%|-%`(nat, nat) @@ -239,8 +239,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 @@ -264,8 +262,8 @@ 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... +== IL Validation after pass sub-expansion... +== Running pass sub... ;; test.spectec relation HasSize: `%|-%`(nat, nat) @@ -275,8 +273,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 @@ -300,8 +296,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))} -== IL Validation after pass sub-expansion... -== Running pass sub... +== IL Validation after pass sub... +== 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 +relation fun_t_totalize_before_fun_t_totalize_case_2: `%`(nat) + ;; test.spectec + rule fun_t_totalize_case_1: + `%`(10) + + ;; test.spectec + rule fun_t_totalize_case_0: + `%`(3) + +;; test.spectec +relation fun_t_totalize: `%%`(nat, nat?) + ;; test.spectec + rule fun_t_totalize_case_0: + `%%`(3, ?(5)) + + ;; test.spectec + rule fun_t_totalize_case_1: + `%%`(10, ?(20)) + + ;; test.spectec + rule fun_t_totalize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_t_totalize_before_fun_t_totalize_case_2: `%`(x0) + +;; test.spectec +relation fun_t_totalize2: `%%`(nat, nat?) + ;; test.spectec + rule fun_t_totalize2_case_0: + `%%`(1, ?(2)) + + ;; test.spectec + rule fun_t_totalize2_case_1{n : nat, var_0 : nat?}: + `%%`(n, var_0) + -- fun_t_totalize: `%%`(n, var_0) + +;; test.spectec +relation fun_t_totalize3: `%%`(nat, nat?) + ;; test.spectec + rule fun_t_totalize3_case_0{n : nat, var_1 : nat?, var_0 : nat?}: + `%%`(n, (iter_val#2 + iter_val#1)?{iter_val#2 <- var_0, iter_val#1 <- var_1}) + -- fun_t_totalize2: `%%`((n + 10), var_1) + -- fun_t_totalize: `%%`(n, var_0) + +== IL Validation after pass definition-to-relation... +== Running pass sideconditions... ;; test.spectec relation HasSize: `%|-%`(nat, nat) @@ -316,27 +369,50 @@ relation TestNestedIter: `%|-%`(nat***, nat**) -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec -def $t_totalize(nat : nat) : nat? +relation fun_t_totalize_before_fun_t_totalize_case_2: `%`(nat) ;; test.spectec - def $t_totalize(3) = ?(5) + rule fun_t_totalize_case_1: + `%`(10) + ;; test.spectec - def $t_totalize(10) = ?(20) - def $t_totalize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_t_totalize_case_0: + `%`(3) ;; test.spectec -def $t_totalize2(nat : nat) : nat? +relation fun_t_totalize: `%%`(nat, nat?) ;; test.spectec - def $t_totalize2(1) = ?(2) + rule fun_t_totalize_case_0: + `%%`(3, ?(5)) + ;; test.spectec - def $t_totalize2{n : nat}(n) = $t_totalize(n) + rule fun_t_totalize_case_1: + `%%`(10, ?(20)) + + ;; test.spectec + rule fun_t_totalize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_t_totalize_before_fun_t_totalize_case_2: `%`(x0) ;; test.spectec -def $t_totalize3(nat : nat) : nat? +relation fun_t_totalize2: `%%`(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))} + rule fun_t_totalize2_case_0: + `%%`(1, ?(2)) -== IL Validation after pass sub... + ;; test.spectec + rule fun_t_totalize2_case_1{n : nat, var_0 : nat?}: + `%%`(n, var_0) + -- fun_t_totalize: `%%`(n, var_0) + +;; test.spectec +relation fun_t_totalize3: `%%`(nat, nat?) + ;; test.spectec + rule fun_t_totalize3_case_0{n : nat, var_1 : nat?, var_0 : nat?}: + `%%`(n, (iter_val#2 + iter_val#1)?{iter_val#2 <- var_0, iter_val#1 <- var_1}) + -- fun_t_totalize2: `%%`((n + 10), var_1) + -- fun_t_totalize: `%%`(n, var_0) + +== IL Validation after pass sideconditions... == Running pass alias-demut... ;; test.spectec @@ -352,25 +428,48 @@ relation TestNestedIter: `%|-%`(nat***, nat**) -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec -def $t_totalize(nat : nat) : nat? +relation fun_t_totalize_before_fun_t_totalize_case_2: `%`(nat) ;; test.spectec - def $t_totalize(3) = ?(5) + rule fun_t_totalize_case_1: + `%`(10) + ;; test.spectec - def $t_totalize(10) = ?(20) - def $t_totalize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_t_totalize_case_0: + `%`(3) ;; test.spectec -def $t_totalize2(nat : nat) : nat? +relation fun_t_totalize: `%%`(nat, nat?) ;; test.spectec - def $t_totalize2(1) = ?(2) + rule fun_t_totalize_case_0: + `%%`(3, ?(5)) + ;; test.spectec - def $t_totalize2{n : nat}(n) = $t_totalize(n) + rule fun_t_totalize_case_1: + `%%`(10, ?(20)) + + ;; test.spectec + rule fun_t_totalize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_t_totalize_before_fun_t_totalize_case_2: `%`(x0) ;; test.spectec -def $t_totalize3(nat : nat) : nat? +relation fun_t_totalize2: `%%`(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))} + rule fun_t_totalize2_case_0: + `%%`(1, ?(2)) + + ;; test.spectec + rule fun_t_totalize2_case_1{n : nat, var_0 : nat?}: + `%%`(n, var_0) + -- fun_t_totalize: `%%`(n, var_0) + +;; test.spectec +relation fun_t_totalize3: `%%`(nat, nat?) + ;; test.spectec + rule fun_t_totalize3_case_0{n : nat, var_1 : nat?, var_0 : nat?}: + `%%`(n, (iter_val#2 + iter_val#1)?{iter_val#2 <- var_0, iter_val#1 <- var_1}) + -- fun_t_totalize2: `%%`((n + 10), var_1) + -- fun_t_totalize: `%%`(n, var_0) == IL Validation after pass alias-demut... == Running pass improve-ids... @@ -388,25 +487,48 @@ relation TestNestedIter: `%|-%`(nat***, nat**) -- (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? +relation fun_t_totalize_before_fun_t_totalize_case_2: `%`(nat) ;; test.spectec - def $t_totalize(3) = ?(5) + rule fun_t_totalize_case_1: + `%`(10) + ;; test.spectec - def $t_totalize(10) = ?(20) - def $t_totalize{x0 : nat}(x0) = ?() - -- otherwise + rule fun_t_totalize_case_0: + `%`(3) ;; test.spectec -def $t_totalize2(nat : nat) : nat? +relation fun_t_totalize: `%%`(nat, nat?) ;; test.spectec - def $t_totalize2(1) = ?(2) + rule fun_t_totalize_case_0: + `%%`(3, ?(5)) + ;; test.spectec - def $t_totalize2{n : nat}(n) = $t_totalize(n) + rule fun_t_totalize_case_1: + `%%`(10, ?(20)) + + ;; test.spectec + rule fun_t_totalize_case_2{x0 : nat}: + `%%`(x0, ?()) + -- ~ fun_t_totalize_before_fun_t_totalize_case_2: `%`(x0) ;; test.spectec -def $t_totalize3(nat : nat) : nat? +relation fun_t_totalize2: `%%`(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))} + rule fun_t_totalize2_case_0: + `%%`(1, ?(2)) + + ;; test.spectec + rule fun_t_totalize2_case_1{n : nat, var_0 : nat?}: + `%%`(n, var_0) + -- fun_t_totalize: `%%`(n, var_0) + +;; test.spectec +relation fun_t_totalize3: `%%`(nat, nat?) + ;; test.spectec + rule fun_t_totalize3_case_0{n : nat, var_1 : nat?, var_0 : nat?}: + `%%`(n, (iter_val#2 + iter_val#1)?{iter_val#2 <- var_0, iter_val#1 <- var_1}) + -- fun_t_totalize2: `%%`((n + 10), var_1) + -- fun_t_totalize: `%%`(n, var_0) == IL Validation after pass improve-ids... == Complete. From 1e64ec4254cce077777a41b79161ac92d91cea30 Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Thu, 26 Feb 2026 12:01:16 +0000 Subject: [PATCH 08/11] Make recursive functions (at the current moment, only the ones with exp params) into relations. --- spectec/src/middlend/deftorel.ml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index c6c3e05523..af2f33ae71 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -595,11 +595,11 @@ let uses_def ids_set def = | _ -> false let rec transform_def (env : env) def = - let must_be_rel_def d = + (* let must_be_rel_def d = match d.it with | DecD (id, params, _, clauses) -> must_be_relation env id params clauses | _ -> false - in + in *) let has_exp_params d = match d.it with | DecD (_, params, _, _) -> List.for_all is_exp_param params @@ -613,7 +613,7 @@ let rec transform_def (env : env) def = 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 defs when List.exists must_be_rel_def defs && List.for_all has_exp_params defs -> + | 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, _, _, _) -> From 33e3ac4cbfa9b2909c346b58d32dd8c622d1b2e3 Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Tue, 21 Apr 2026 15:43:57 +0100 Subject: [PATCH 09/11] Made it so that functions with only else premises are allowed as functions --- spectec/src/middlend/deftorel.ml | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index af2f33ae71..26830a332c 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -458,6 +458,11 @@ let collect_list_length_vars () : StringSet.t ref * (module Iter.Arg) = in Arg.acc, (module Arg) let must_be_relation env id params clauses = + let only_otherwise prems = + match prems with + | [{it = ElsePr; _}] -> 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); @@ -471,7 +476,10 @@ let must_be_relation env id params clauses = | DefD (quants, args, exp, prems) -> Acc.args args; (* Premises might not be decidable *) - prems <> [] || + (* NOTE: if its only otherwise premise, then fall-through semantics should be + able to handle it. + *) + (prems <> [] && not (only_otherwise 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 || From a615206e63aa578927e3894743eda33b72a1290e Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Mon, 18 May 2026 15:54:24 +0100 Subject: [PATCH 10/11] Fix tests --- .../09-definition-to-relation.il | 1495 +++++++--------- .../specification.exp/10-sideconditions.il | 1550 ++++++++--------- .../specification.exp/11-alias-demut.il | 1550 ++++++++--------- .../specification.exp/12-improve-ids.il | 1550 ++++++++--------- spectec/test-middlend/test.spectec.exp | 172 +- 5 files changed, 2762 insertions(+), 3555 deletions(-) diff --git a/spectec/test-middlend/specification.exp/09-definition-to-relation.il b/spectec/test-middlend/specification.exp/09-definition-to-relation.il index 0ed7062260..0f3652560e 100644 --- a/spectec/test-middlend/specification.exp/09-definition-to-relation.il +++ b/spectec/test-middlend/specification.exp/09-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 @@ -244,68 +252,32 @@ syntax i64 = iN syntax i128 = iN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_signif_before_fun_signif_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_signif: `%%`(N, nat?) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_0: - `%%`(32, ?(23)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_1: - `%%`(64, ?(52)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_signif_before_fun_signif_case_2: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_expon_before_fun_expon_case_2: `%`(N) +def $signif(N : N) : nat? ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_1: - `%`(64) - + def $signif(32) = ?(23) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_0: - `%`(32) + def $signif(64) = ?(52) + def $signif{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_expon: `%%`(N, nat?) +def $expon(N : N) : nat? ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_0: - `%%`(32, ?(8)) - + def $expon(32) = ?(8) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_1: - `%%`(64, ?(11)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_expon_before_fun_expon_case_2: `%`(x0) + def $expon(64) = ?(11) + def $expon{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_M: `%%`(N, nat) +def $M(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_M_case_0{N : nat, var_0 : nat?}: - `%%`(N, !(var_0)) - -- fun_signif: `%%`(N, var_0) + def $M{N : nat}(N) = !($signif(N)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_E: `%%`(N, nat) +def $E(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_E_case_0{N : nat, var_0 : nat?}: - `%%`(N, !(var_0)) - -- fun_expon: `%%`(N, var_0) + def $E{N : nat}(N) = !($expon(N)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax exp = int @@ -320,28 +292,23 @@ syntax fNmag = ;; ../../../../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, var_1 : nat, var_0 : nat}: + rule fNmag_case_0{N : N, m : m, exp : exp}: `%%`(N, NORM_fNmag(m, exp)) - -- if ((m < (2 ^ var_0)) /\ ((((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= exp) /\ (exp <= (((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) - -- fun_E: `%%`(N, var_1) - -- fun_M: `%%`(N, var_0) + -- 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, var_1 : nat, var_0 : nat}: + rule fNmag_case_1{N : N, exp : exp, m : m}: `%%`(N, SUBNORM_fNmag(m)) - -- if ((m < (2 ^ var_0)) /\ (((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = exp)) - -- fun_E: `%%`(N, var_1) - -- fun_M: `%%`(N, var_0) + -- 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, var_0 : nat}: + rule fNmag_case_3{N : N, m : m}: `%%`(N, NAN_fNmag(m)) - -- if ((1 <= m) /\ (m < (2 ^ var_0))) - -- fun_M: `%%`(N, var_0) + -- if ((1 <= m) /\ (m < (2 ^ $M(N)))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax fN = @@ -388,11 +355,9 @@ relation fun_fone: `%%`(N, fN) -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_canon_: `%%`(N, nat) +def $canon_(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_canon__case_0{N : nat, var_0 : nat?}: - `%%`(N, (2 ^ (((!(var_0) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) - -- fun_signif: `%%`(N, var_0) + 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 @@ -580,66 +545,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 @@ -1492,95 +1492,35 @@ relation wf_moduletype: `%`(moduletype) -- (wf_externtype: `%`(`externtype*_0`))*{`externtype*_0` <- `externtype*_0`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_IN_before_fun_IN_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_IN: `%%`(N, Inn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_0: - `%%`(32, ?(I32_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_1: - `%%`(64, ?(I64_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_IN_before_fun_IN_case_2: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_FN_before_fun_FN_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_FN: `%%`(N, Fnn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_0: - `%%`(32, ?(F32_Fnn)) - +def $IN(N : N) : Inn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_1: - `%%`(64, ?(F64_Fnn)) - + def $IN(32) = ?(I32_Inn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_FN_before_fun_FN_case_2: `%`(x0) + def $IN(64) = ?(I64_Inn) + def $IN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_JN_before_fun_JN_case_4: `%`(N) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_3: - `%`(64) - +def $FN(N : N) : Fnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_2: - `%`(32) - + def $FN(32) = ?(F32_Fnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_1: - `%`(16) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_0: - `%`(8) + def $FN(64) = ?(F64_Fnn) + def $FN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_JN: `%%`(N, Jnn?) +def $JN(N : N) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_0: - `%%`(8, ?(I8_Jnn)) - + def $JN(8) = ?(I8_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_1: - `%%`(16, ?(I16_Jnn)) - + def $JN(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_2: - `%%`(32, ?(I32_Jnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_3: - `%%`(64, ?(I64_Jnn)) - + def $JN(32) = ?(I32_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_4{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_JN_before_fun_JN_case_4: `%`(x0) + 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 @@ -1621,69 +1561,23 @@ def $lsize(lanetype : lanetype) : nat def $lsize(I16_lanetype) = $psize(I16_packtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_zsize_before_fun_zsize_case_7: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_zsize: `%%`(storagetype, nat?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_0: - `%%`(I32_storagetype, ?($size(I32_numtype))) - +def $zsize(storagetype : storagetype) : nat? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_1: - `%%`(I64_storagetype, ?($size(I64_numtype))) - + def $zsize(I32_storagetype) = ?($size(I32_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_2: - `%%`(F32_storagetype, ?($size(F32_numtype))) - + def $zsize(I64_storagetype) = ?($size(I64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_3: - `%%`(F64_storagetype, ?($size(F64_numtype))) - + def $zsize(F32_storagetype) = ?($size(F32_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_4: - `%%`(V128_storagetype, ?($vsize(V128_vectype))) - + def $zsize(F64_storagetype) = ?($size(F64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_5: - `%%`(I8_storagetype, ?($psize(I8_packtype))) - + def $zsize(V128_storagetype) = ?($vsize(V128_vectype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_6: - `%%`(I16_storagetype, ?($psize(I16_packtype))) - + def $zsize(I8_storagetype) = ?($psize(I8_packtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_7{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_zsize_before_fun_zsize_case_7: `%`(x0) + 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 @@ -1701,69 +1595,31 @@ def $fsize(Fnn : Fnn) : nat def $fsize{Fnn : Fnn}(Fnn) = $size($numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_isize_before_fun_inv_isize_case_2: `%`(nat) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_isize: `%%`(nat, Inn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_0: - `%%`(32, ?(I32_Inn)) - +def $inv_isize(nat : nat) : Inn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_1: - `%%`(64, ?(I64_Inn)) - + def $inv_isize(32) = ?(I32_Inn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_inv_isize_before_fun_inv_isize_case_2: `%`(x0) + def $inv_isize(64) = ?(I64_Inn) + def $inv_isize{x0 : nat}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_jsize: `%%`(nat, Jnn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_0: - `%%`(8, ?(I8_Jnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_1: - `%%`(16, ?(I16_Jnn)) - +def $inv_jsize(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_2{n : nat, var_0 : Inn?}: - `%%`(n, $Jnn_addrtype(iter_val#1)?{iter_val#1 <- var_0}) - -- fun_inv_isize: `%%`(n, var_0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(nat) + def $inv_jsize(8) = ?(I8_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_1: - `%`(64) - + def $inv_jsize(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_0: - `%`(32) + 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 -relation fun_inv_fsize: `%%`(nat, Fnn?) +def $inv_fsize(nat : nat) : Fnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_0: - `%%`(32, ?(F32_Fnn)) - + def $inv_fsize(32) = ?(F32_Fnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_1: - `%%`(64, ?(F64_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(x0) + 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 @@ -1811,11 +1667,9 @@ def $jsizenn(Jnn : Jnn) : nat def $jsizenn{Jnn : Jnn}(Jnn) = $lsize($lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_jsizenn: `%%`(nat, Jnn?) +def $inv_jsizenn(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsizenn_case_0{n : nat, var_0 : Jnn?}: - `%%`(n, var_0) - -- fun_inv_jsize: `%%`(n, var_0) + def $inv_jsizenn{n : nat}(n) = $inv_jsize(n) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lunpack(lanetype : lanetype) : numtype @@ -1873,191 +1727,59 @@ relation fun_unpack: `%%`(storagetype, valtype) -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_nunpack_before_fun_nunpack_case_6: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_5: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_4: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_nunpack: `%%`(storagetype, numtype?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_0: - `%%`(I32_storagetype, ?(I32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_1: - `%%`(I64_storagetype, ?(I64_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_2: - `%%`(F32_storagetype, ?(F32_numtype)) - +def $nunpack(storagetype : storagetype) : numtype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_3: - `%%`(F64_storagetype, ?(F64_numtype)) - + def $nunpack(I32_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_4: - `%%`(I8_storagetype, ?(I32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_5: - `%%`(I16_storagetype, ?(I32_numtype)) - + def $nunpack(I64_storagetype) = ?(I64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_6{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_nunpack_before_fun_nunpack_case_6: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_vunpack_before_fun_vunpack_case_1: `%`(storagetype) + def $nunpack(F32_storagetype) = ?(F32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_0: - `%`(V128_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_vunpack: `%%`(storagetype, vectype?) + def $nunpack(F64_storagetype) = ?(F64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_0: - `%%`(V128_storagetype, ?(V128_vectype)) - + def $nunpack(I8_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_1{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_vunpack_before_fun_vunpack_case_1: `%`(x0) + def $nunpack(I16_storagetype) = ?(I32_numtype) + def $nunpack{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_cunpack_before_fun_cunpack_case_13: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_12: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_11: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_10: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_9: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_8: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_7: - `%`(I32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_1: - `%`(I64_storagetype) - +def $vunpack(storagetype : storagetype) : vectype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_0: - `%`(I32_storagetype) + def $vunpack(V128_storagetype) = ?(V128_vectype) + def $vunpack{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_cunpack: `%%`(storagetype, consttype?) +def $cunpack(storagetype : storagetype) : consttype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_0: - `%%`(I32_storagetype, ?(I32_consttype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_1: - `%%`(I64_storagetype, ?(I64_consttype)) - + def $cunpack(I32_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_2: - `%%`(F32_storagetype, ?(F32_consttype)) - + def $cunpack(I64_storagetype) = ?(I64_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_3: - `%%`(F64_storagetype, ?(F64_consttype)) - + def $cunpack(F32_storagetype) = ?(F32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_4: - `%%`(V128_storagetype, ?(V128_consttype)) - + def $cunpack(F64_storagetype) = ?(F64_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_5: - `%%`(I8_storagetype, ?(I32_consttype)) - + def $cunpack(V128_storagetype) = ?(V128_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_6: - `%%`(I16_storagetype, ?(I32_consttype)) - + def $cunpack(I8_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_7: - `%%`(I32_storagetype, ?($consttype_numtype($lunpack(I32_lanetype)))) - + def $cunpack(I16_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_8: - `%%`(I64_storagetype, ?($consttype_numtype($lunpack(I64_lanetype)))) - + def $cunpack(I32_storagetype) = ?($consttype_numtype($lunpack(I32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_9: - `%%`(F32_storagetype, ?($consttype_numtype($lunpack(F32_lanetype)))) - + def $cunpack(I64_storagetype) = ?($consttype_numtype($lunpack(I64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_10: - `%%`(F64_storagetype, ?($consttype_numtype($lunpack(F64_lanetype)))) - + def $cunpack(F32_storagetype) = ?($consttype_numtype($lunpack(F32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_11: - `%%`(I8_storagetype, ?($consttype_numtype($lunpack(I8_lanetype)))) - + def $cunpack(F64_storagetype) = ?($consttype_numtype($lunpack(F64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_12: - `%%`(I16_storagetype, ?($consttype_numtype($lunpack(I16_lanetype)))) - + def $cunpack(I8_storagetype) = ?($consttype_numtype($lunpack(I8_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_13{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_cunpack_before_fun_cunpack_case_13: `%`(x0) + 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 @@ -2077,85 +1799,110 @@ relation fun_diffrt: `%%%`(reftype, reftype, reftype) -- wf_reftype: `%`(REF_reftype(null_1#3?{null_1#3 <- `null_1?`}, ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_as_deftype_before_fun_as_deftype_case_1: `%`(typeuse) +def $as_deftype(typeuse : typeuse) : deftype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_0{rectype : rectype, n : n}: - `%`(_DEF_typeuse(rectype, n)) + 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 -relation fun_as_deftype: `%%`(typeuse, deftype?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_0{rectype : rectype, n : n}: - `%%`(_DEF_typeuse(rectype, n), ?(_DEF_deftype(rectype, n))) +rec { - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_1{x0 : typeuse}: - `%%`(x0, ?()) - -- ~ fun_as_deftype_before_fun_as_deftype_case_1: `%`(x0) +;; ../../../../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 -rec { + ;; ../../../../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.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 + 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: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: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: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: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: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 @@ -7476,24 +7223,22 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../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*, var_0 : deftype?}: + rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- Expand: `%~~%`(!(var_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([]))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`}), C.LABELS_context[$proj_uN_0(l).0]) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*, var_0 : deftype?}: + rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- Expand: `%~~%`(!(var_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([]))) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t*{t <- `t*`} ++ [REF_valtype(?(), EXN_heaptype)]), C.LABELS_context[$proj_uN_0(l).0]) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: @@ -7859,16 +7604,15 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*, var_0 : deftype?}: + 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*`}))) -- 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*`}))) - -- Expand: `%~~%`(!(var_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([]))) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1*{t_1 <- `t_1*`}), [], `%`_resulttype(t_2*{t_2 <- `t_2*`}))) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:171.1-173.42 rule throw_ref{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: @@ -9116,7 +8860,7 @@ relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../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*, var_1 : funcidx*, var_0 : 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*, 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) -- wf_context: `%`(C) -- wf_context: `%`(C') @@ -9143,11 +8887,16 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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*`} = var_1) - -- 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 (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) + -- 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) @@ -9296,69 +9045,23 @@ relation fun_inv_signed_: `%%%`(N, 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 -relation fun_sx_before_fun_sx_case_7: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -relation fun_sx: `%%`(storagetype, sx??) +def $sx(storagetype : storagetype) : sx?? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_0: - `%%`(I32_storagetype, ?(?())) - + def $sx(I32_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_1: - `%%`(I64_storagetype, ?(?())) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_2: - `%%`(F32_storagetype, ?(?())) - + def $sx(I64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_3: - `%%`(F64_storagetype, ?(?())) - + def $sx(F32_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_4: - `%%`(V128_storagetype, ?(?())) - + def $sx(F64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_5: - `%%`(I8_storagetype, ?(?(S_sx))) - + def $sx(V128_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_6: - `%%`(I16_storagetype, ?(?(S_sx))) - + def $sx(I8_storagetype) = ?(?(S_sx)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_7{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_sx_before_fun_sx_case_7: `%`(x0) + def $sx(I16_storagetype) = ?(?(S_sx)) + def $sx{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec relation fun_zero: `%%`(lanetype, lane_) @@ -9912,16 +9615,14 @@ relation fun_cunpacknum_: `%%%`(storagetype, lit_, lit_) `%%%`(V128_storagetype, c, c) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_cunpacknum__case_5{c : uN, var_0 : consttype?}: + rule fun_cunpacknum__case_5{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)))) - -- fun_cunpack: `%%`($storagetype_packtype(I8_packtype), var_0) - -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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 - rule fun_cunpacknum__case_6{c : uN, var_0 : consttype?}: + rule fun_cunpacknum__case_6{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)))) - -- fun_cunpack: `%%`($storagetype_packtype(I16_packtype), var_0) - -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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 fun_unop_: `%%%%`(numtype, unop_, num_, num_*) @@ -15243,66 +14944,101 @@ relation fun_unpackfield_: `%%%%`(storagetype, sx?, fieldval, 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 @@ -16412,7 +16148,7 @@ relation Step_pure: `%~>%`(instr*, 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_*, `var_0*` : uN*}: + rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*, `var_1*` : uN*, 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)]) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), i))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) @@ -16420,8 +16156,9 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_instr: `%`(CONST_instr(I32_numtype, c)) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) - -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0(var_0).0*{var_0 <- `var_0*`})) - -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_0))*{var_0 <- `var_0*`, i <- `i*`} + -- if ($proj_uN_0(!($proj_num__0(c))).0 = var_0) + -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_1))*{var_1 <- `var_1*`, i <- `i*`} + -- fun_prod: `%%`($proj_uN_0(var_1).0*{var_1 <- `var_1*`}, 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_, var_0 : vec_}: @@ -16939,7 +16676,7 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype, var_0 : sx??}: + rule `array.copy-le_0`{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)])) -- 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)) @@ -16955,8 +16692,7 @@ relation `Step_read_before_array.copy-gt`: `%`(config) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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?`} = !(var_0))) - -- fun_sx: `%%`(zt_2, var_0) + -- 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)))) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx}: @@ -17021,14 +16757,13 @@ relation `Step_read_before_array.init_elem-succ`: `%`(config) ;; ../../../../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_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: + 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)])) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) ;; ../../../../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}: @@ -17047,14 +16782,13 @@ relation `Step_read_before_array.init_data-num`: `%`(config) -- if (n = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: + 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)])) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) ;; ../../../../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}: @@ -17715,28 +17449,25 @@ relation Step_read: `%~>%`(config, instr*) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : 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, var_0 : nat?}: + 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]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) ;; ../../../../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?, var_3 : nat?, `var_2*` : lit_*, var_1 : consttype?, `var_0*` : instr*}: + rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?, `var_1*` : lit_*, `var_0*` : 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)]), var_0^n{var_0 <- `var_0*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- (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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !(var_3)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- fun_zsize: `%%`(zt, var_3) - -- (fun_cunpacknum_: `%%%`(zt, c, var_2))^n{var_2 <- `var_2*`, c <- `c*`} - -- fun_cunpack: `%%`(zt, var_1) - -- (fun_const: `%%%`(!(var_1), var_2, var_0))^n{var_2 <- `var_2*`, var_0 <- `var_0*`} + -- 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)]) + -- (fun_cunpacknum_: `%%%`(zt, c, var_1))^n{var_1 <- `var_1*`, c <- `c*`} + -- (fun_const: `%%%`(!($cunpack(zt)), var_1, var_0))^n{var_1 <- `var_1*`, var_0 <- `var_0*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -17837,7 +17568,7 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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, var_0 : sx??}: + 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)]) -- 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)) @@ -17853,11 +17584,10 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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?`} = !(var_0))) - -- fun_sx: `%%`(zt_2, var_0) + -- 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)))) ;; ../../../../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, var_0 : sx??}: + 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)]) -- 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)) @@ -17873,8 +17603,7 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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?`} = !(var_0)) - -- fun_sx: `%%`(zt_2, var_0) + -- if (sx?{sx <- `sx?`} = !($sx(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}: @@ -17932,14 +17661,13 @@ relation Step_read: `%~>%`(config, instr*) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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, var_0 : nat?}: + 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]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !($zsize(zt))) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) ;; ../../../../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}: @@ -17949,25 +17677,23 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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?, var_3 : nat?, var_2 : lit_, var_1 : consttype?, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 + (((!(var_3) : 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)]) + 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?, var_1 : lit_, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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)]) -- 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_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 + (((!(var_3) : 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(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))) -- ~ `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 : (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- fun_zsize: `%%`(zt, var_3) - -- fun_cunpacknum_: `%%%`(zt, c, var_2) - -- fun_cunpack: `%%`(zt, var_1) - -- fun_const: `%%%`(!(var_1), var_2, var_0) + -- 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)]) + -- fun_cunpacknum_: `%%%`(zt, c, var_1) + -- fun_const: `%%%`(!($cunpack(zt)), var_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rec { @@ -18026,16 +17752,15 @@ relation Step: `%~>%`(config, config) -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr*{instr <- `instr*`}), `%;%`_config(`%;%`_state(s', f''), instr'*{instr' <- `instr'*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:231.1-235.49 - rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_1 : deftype?, var_0 : state}: + rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_0 : state}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config(var_0, [`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*`}}) - -- Expand: `%~~%`(!(var_1), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) + -- 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*`}}) - -- fun_as_deftype: `%%`($tag(z, x).TYPE_taginst, var_1) -- fun_add_exninst: `%%%`(z, [exn], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:309.1-310.56 @@ -18532,22 +18257,27 @@ relation fun_allocexports: `%%%`(moduleinst, export*, exportinst*) ;; ../../../../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 - 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_13 : exportinst*, var_12 : (store, funcaddr*), `var_11*` : elemtype*, var_10 : (store, elemaddr*), var_9 : (store, dataaddr*), `var_8*` : tabletype*, var_7 : (store, tableaddr*), `var_6*` : memtype*, var_5 : (store, memaddr*), `var_4*` : globaltype*, var_3 : (store, globaladdr*), `var_2*` : tagtype*, var_1 : (store, tagaddr*), var_0 : deftype*}: + 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_18 : 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)) - -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_13) - -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_12) - -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_11))*{var_11 <- `var_11*`, elemtype#3 <- `elemtype*`} - -- fun_allocelems: `%%%%`(s_5, var_11*{var_11 <- `var_11*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_10) - -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_9) - -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_8))*{var_8 <- `var_8*`, tabletype#160 <- `tabletype*`} - -- fun_alloctables: `%%%%`(s_3, var_8*{var_8 <- `var_8*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_7) - -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_6))*{var_6 <- `var_6*`, memtype#126 <- `memtype*`} - -- fun_allocmems: `%%%`(s_2, var_6*{var_6 <- `var_6*`}, var_5) - -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_4))*{var_4 <- `var_4*`, globaltype#126 <- `globaltype*`} - -- fun_allocglobals: `%%%%`(s_1, var_4*{var_4 <- `var_4*`}, val_G#2*{val_G#2 <- `val_G*`}, var_3) - -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_2))*{var_2 <- `var_2*`, tagtype#82 <- `tagtype*`} - -- fun_alloctags: `%%%`(s, var_2*{var_2 <- `var_2*`}, var_1) - -- fun_alloctypes: `%%`(type#4*{type#4 <- `type*`}, var_0) + -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `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#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `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#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `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) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(moduleinst) -- wf_store: `%`(s_1) @@ -18574,21 +18304,21 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* -- if (func#5*{func#5 <- `func*`} = FUNC_func(x#3, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#3 <- `x*`}) -- if (data#4*{data#4 <- `data*`} = DATA_data(byte#6*{byte#6 <- `byte*#112`}, datamode#112)*{`byte*#112` <- `byte**`, datamode#112 <- `datamode*`}) -- if (elem#6*{elem#6 <- `elem*`} = ELEM_elem(elemtype#2, expr_E#2*{expr_E#2 <- `expr_E*#2`}, elemmode#232)*{elemmode#232 <- `elemmode*`, elemtype#2 <- `elemtype*`, `expr_E*#2` <- `expr_E**`}) - -- if (aa_I#3*{aa_I#3 <- `aa_I*`} = $tagsxa(externaddr#2*{externaddr#2 <- `externaddr*`})) - -- if (ga_I#3*{ga_I#3 <- `ga_I*`} = $globalsxa(externaddr#3*{externaddr#3 <- `externaddr*`})) - -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`})) - -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = $tablesxa(externaddr#5*{externaddr#5 <- `externaddr*`})) - -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = $funcsxa(externaddr#6*{externaddr#6 <- `externaddr*`})) - -- if (dt#9*{dt#9 <- `dt*`} = var_0) + -- if (aa_I#3*{aa_I#3 <- `aa_I*`} = var_0) + -- if (ga_I#3*{ga_I#3 <- `ga_I*`} = var_1) + -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = var_2) + -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = var_3) + -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = var_4) + -- if (dt#9*{dt#9 <- `dt*`} = var_5) -- if (fa#3*{fa#3 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#6*{func#6 <- `func*`}|){}) - -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_1) - -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_3) - -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_5) - -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_7) - -- if ((s_5, da#2*{da#2 <- `da*`}) = var_9) - -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_10) - -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_12) - -- if (xi#2*{xi#2 <- `xi*`} = var_13) + -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_6) + -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_8) + -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_10) + -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_12) + -- if ((s_5, da#2*{da#2 <- `da*`}) = var_14) + -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_15) + -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_17) + -- if (xi#2*{xi#2 <- `xi*`} = var_18) -- if (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 @@ -18696,15 +18426,19 @@ relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_7*` : instr**, `var_6*` : instr**, var_5 : (store, moduleinst), var_4 : (state, ref**), var_3 : (state, ref*), var_2 : (state, val*), var_1 : deftype*, var_0 : deftype*}: + rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_11*` : instr**, `var_10*` : instr**, var_9 : (store, moduleinst), var_8 : (state, ref**), var_7 : (state, ref*), var_6 : (state, val*), var_5 : funcaddr*, var_4 : globaladdr*, var_3 : deftype*, 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?`}))) - -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_7))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`} - -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_6))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`} - -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_5) - -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_4) - -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_3) - -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_2) - -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_1) + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) + -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) + -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') @@ -18721,7 +18455,7 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- (wf_data: `%`(DATA_data(byte#8*{byte#8 <- `byte*#117`}, datamode#116)))*{`byte*#117` <- `byte**`, datamode#116 <- `datamode*`} -- (wf_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*`} -- (wf_start: `%`(START_start(x#6)))?{x#6 <- `x?`} - -- wf_moduleinst: `%`({TYPES var_0, TAGS [], GLOBALS $globalsxa(externaddr#8*{externaddr#8 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#9*{externaddr#9 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({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 []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#1)))^(i_D#1<|data#7*{data#7 <- `data*`}|){} @@ -18735,15 +18469,15 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (data#9*{data#9 <- `data*`} = DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`}) -- if (elem#10*{elem#10 <- `elem*`} = ELEM_elem(reftype#519, expr_E#4*{expr_E#4 <- `expr_E*#4`}, elemmode#239)*{elemmode#239 <- `elemmode*`, `expr_E*#4` <- `expr_E**`, reftype#519 <- `reftype*`}) -- if (start#8?{start#8 <- `start?`} = START_start(x#8)?{x#8 <- `x?`}) - -- if (moduleinst_0 = {TYPES var_1, TAGS [], GLOBALS $globalsxa(externaddr#11*{externaddr#11 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#12*{externaddr#12 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- if (moduleinst_0 = {TYPES var_3, TAGS [], GLOBALS var_4, MEMS [], TABLES [], FUNCS var_5 ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_2) - -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_3) - -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_4) + -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_6) + -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_7) + -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_8) -- if (z''' = `%;%`_state(s''', f)) - -- if ((s'''', moduleinst) = var_5) - -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_6^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`})) - -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_7^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`})) + -- if ((s'''', moduleinst) = var_9) + -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_10^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`})) + -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_11^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`})) -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -18966,156 +18700,240 @@ 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.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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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 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 relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule fun_ordered_case_0{`decl*` : decl*}: + rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: `%%`(decl#1*{decl#1 <- `decl*`}, true) - -- if ($importsd(decl#2*{decl#2 <- `decl*`}) = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) + -- if (var_0 = []) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule fun_ordered_case_1{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) @@ -21852,12 +21670,10 @@ grammar TfNmag(N : N) : fNmag ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod "inf" => INF_fNmag ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{var_0 : m} "nan" => NAN_fNmag(var_0) - -- fun_canon_: `%%`(N, var_0) + prod "nan" => NAN_fNmag($canon_(N)) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{n : n, var_0 : nat?} {{"nan:0x"} {n:Thexnum}} => NAN_fNmag(n) - -- if ((1 <= n) /\ (n < (2 ^ !(var_0)))) - -- fun_signif: `%%`(N, var_0) + 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 @@ -23477,22 +23293,33 @@ 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, var_1 : bool, 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*`})) + 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 var_1 - -- fun_ordered: `%%`(decl*{decl <- `decl*`}, var_1) + -- 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 diff --git a/spectec/test-middlend/specification.exp/10-sideconditions.il b/spectec/test-middlend/specification.exp/10-sideconditions.il index cea5af435d..b3f95eeb4c 100644 --- a/spectec/test-middlend/specification.exp/10-sideconditions.il +++ b/spectec/test-middlend/specification.exp/10-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'#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 @@ -244,70 +252,32 @@ syntax i64 = iN syntax i128 = iN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_signif_before_fun_signif_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_1: - `%`(64) - +def $signif(N : N) : nat? ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_signif: `%%`(N, nat?) + def $signif(32) = ?(23) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_0: - `%%`(32, ?(23)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_1: - `%%`(64, ?(52)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_signif_before_fun_signif_case_2: `%`(x0) + def $signif(64) = ?(52) + def $signif{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_expon_before_fun_expon_case_2: `%`(N) +def $expon(N : N) : nat? ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_1: - `%`(64) - + def $expon(32) = ?(8) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_0: - `%`(32) + def $expon(64) = ?(11) + def $expon{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_expon: `%%`(N, nat?) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_0: - `%%`(32, ?(8)) - +def $M(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_1: - `%%`(64, ?(11)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_expon_before_fun_expon_case_2: `%`(x0) + def $M{N : nat}(N) = !($signif(N)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_M: `%%`(N, nat) +def $E(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_M_case_0{N : nat, var_0 : nat?}: - `%%`(N, !(var_0)) - -- if (var_0 =/= ?()) - -- fun_signif: `%%`(N, var_0) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_E: `%%`(N, nat) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_E_case_0{N : nat, var_0 : nat?}: - `%%`(N, !(var_0)) - -- if (var_0 =/= ?()) - -- fun_expon: `%%`(N, var_0) + def $E{N : nat}(N) = !($expon(N)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax exp = int @@ -322,28 +292,23 @@ syntax fNmag = ;; ../../../../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, var_1 : nat, var_0 : nat}: + rule fNmag_case_0{N : N, m : m, exp : exp}: `%%`(N, NORM_fNmag(m, exp)) - -- if ((m < (2 ^ var_0)) /\ ((((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= exp) /\ (exp <= (((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) - -- fun_E: `%%`(N, var_1) - -- fun_M: `%%`(N, var_0) + -- 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, var_1 : nat, var_0 : nat}: + rule fNmag_case_1{N : N, exp : exp, m : m}: `%%`(N, SUBNORM_fNmag(m)) - -- if ((m < (2 ^ var_0)) /\ (((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = exp)) - -- fun_E: `%%`(N, var_1) - -- fun_M: `%%`(N, var_0) + -- 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, var_0 : nat}: + rule fNmag_case_3{N : N, m : m}: `%%`(N, NAN_fNmag(m)) - -- if ((1 <= m) /\ (m < (2 ^ var_0))) - -- fun_M: `%%`(N, var_0) + -- if ((1 <= m) /\ (m < (2 ^ $M(N)))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax fN = @@ -390,12 +355,9 @@ relation fun_fone: `%%`(N, fN) -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_canon_: `%%`(N, nat) +def $canon_(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_canon__case_0{N : nat, var_0 : nat?}: - `%%`(N, (2 ^ (((!(var_0) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) - -- if (var_0 =/= ?()) - -- fun_signif: `%%`(N, var_0) + 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 @@ -584,66 +546,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 @@ -1495,95 +1492,35 @@ relation wf_moduletype: `%`(moduletype) -- (wf_externtype: `%`(`externtype*_0`))*{`externtype*_0` <- `externtype*_0`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_IN_before_fun_IN_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_IN: `%%`(N, Inn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_0: - `%%`(32, ?(I32_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_1: - `%%`(64, ?(I64_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_IN_before_fun_IN_case_2: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_FN_before_fun_FN_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_FN: `%%`(N, Fnn?) +def $IN(N : N) : Inn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_0: - `%%`(32, ?(F32_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_1: - `%%`(64, ?(F64_Fnn)) - + def $IN(32) = ?(I32_Inn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_FN_before_fun_FN_case_2: `%`(x0) + def $IN(64) = ?(I64_Inn) + def $IN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_JN_before_fun_JN_case_4: `%`(N) +def $FN(N : N) : Fnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_3: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_2: - `%`(32) - + def $FN(32) = ?(F32_Fnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_1: - `%`(16) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_0: - `%`(8) + def $FN(64) = ?(F64_Fnn) + def $FN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_JN: `%%`(N, Jnn?) +def $JN(N : N) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_0: - `%%`(8, ?(I8_Jnn)) - + def $JN(8) = ?(I8_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_1: - `%%`(16, ?(I16_Jnn)) - + def $JN(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_2: - `%%`(32, ?(I32_Jnn)) - + def $JN(32) = ?(I32_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_3: - `%%`(64, ?(I64_Jnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_4{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_JN_before_fun_JN_case_4: `%`(x0) + 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 @@ -1624,69 +1561,23 @@ def $lsize(lanetype : lanetype) : nat def $lsize(I16_lanetype) = $psize(I16_packtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_zsize_before_fun_zsize_case_7: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_zsize: `%%`(storagetype, nat?) +def $zsize(storagetype : storagetype) : nat? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_0: - `%%`(I32_storagetype, ?($size(I32_numtype))) - + def $zsize(I32_storagetype) = ?($size(I32_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_1: - `%%`(I64_storagetype, ?($size(I64_numtype))) - + def $zsize(I64_storagetype) = ?($size(I64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_2: - `%%`(F32_storagetype, ?($size(F32_numtype))) - + def $zsize(F32_storagetype) = ?($size(F32_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_3: - `%%`(F64_storagetype, ?($size(F64_numtype))) - + def $zsize(F64_storagetype) = ?($size(F64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_4: - `%%`(V128_storagetype, ?($vsize(V128_vectype))) - + def $zsize(V128_storagetype) = ?($vsize(V128_vectype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_5: - `%%`(I8_storagetype, ?($psize(I8_packtype))) - + def $zsize(I8_storagetype) = ?($psize(I8_packtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_6: - `%%`(I16_storagetype, ?($psize(I16_packtype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_7{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_zsize_before_fun_zsize_case_7: `%`(x0) + 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 @@ -1704,69 +1595,31 @@ def $fsize(Fnn : Fnn) : nat def $fsize{Fnn : Fnn}(Fnn) = $size($numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_isize_before_fun_inv_isize_case_2: `%`(nat) +def $inv_isize(nat : nat) : Inn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_1: - `%`(64) - + def $inv_isize(32) = ?(I32_Inn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_0: - `%`(32) + def $inv_isize(64) = ?(I64_Inn) + def $inv_isize{x0 : nat}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_isize: `%%`(nat, Inn?) +def $inv_jsize(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_0: - `%%`(32, ?(I32_Inn)) - + def $inv_jsize(8) = ?(I8_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_1: - `%%`(64, ?(I64_Inn)) - + def $inv_jsize(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_inv_isize_before_fun_inv_isize_case_2: `%`(x0) + 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 -relation fun_inv_jsize: `%%`(nat, Jnn?) +def $inv_fsize(nat : nat) : Fnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_0: - `%%`(8, ?(I8_Jnn)) - + def $inv_fsize(32) = ?(F32_Fnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_1: - `%%`(16, ?(I16_Jnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_2{n : nat, var_0 : Inn?}: - `%%`(n, $Jnn_addrtype(iter_val#1)?{iter_val#1 <- var_0}) - -- fun_inv_isize: `%%`(n, var_0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(nat) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_fsize: `%%`(nat, Fnn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_0: - `%%`(32, ?(F32_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_1: - `%%`(64, ?(F64_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(x0) + 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 @@ -1814,11 +1667,9 @@ def $jsizenn(Jnn : Jnn) : nat def $jsizenn{Jnn : Jnn}(Jnn) = $lsize($lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_jsizenn: `%%`(nat, Jnn?) +def $inv_jsizenn(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsizenn_case_0{n : nat, var_0 : Jnn?}: - `%%`(n, var_0) - -- fun_inv_jsize: `%%`(n, var_0) + def $inv_jsizenn{n : nat}(n) = $inv_jsize(n) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lunpack(lanetype : lanetype) : numtype @@ -1876,191 +1727,59 @@ relation fun_unpack: `%%`(storagetype, valtype) -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_nunpack_before_fun_nunpack_case_6: `%`(storagetype) +def $nunpack(storagetype : storagetype) : numtype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_5: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_4: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_2: - `%`(F32_storagetype) - + def $nunpack(I32_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_1: - `%`(I64_storagetype) - + def $nunpack(I64_storagetype) = ?(I64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_nunpack: `%%`(storagetype, numtype?) + def $nunpack(F32_storagetype) = ?(F32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_0: - `%%`(I32_storagetype, ?(I32_numtype)) - + def $nunpack(F64_storagetype) = ?(F64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_1: - `%%`(I64_storagetype, ?(I64_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_2: - `%%`(F32_storagetype, ?(F32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_3: - `%%`(F64_storagetype, ?(F64_numtype)) - + def $nunpack(I8_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_4: - `%%`(I8_storagetype, ?(I32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_5: - `%%`(I16_storagetype, ?(I32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_6{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_nunpack_before_fun_nunpack_case_6: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_vunpack_before_fun_vunpack_case_1: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_0: - `%`(V128_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_vunpack: `%%`(storagetype, vectype?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_0: - `%%`(V128_storagetype, ?(V128_vectype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_1{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_vunpack_before_fun_vunpack_case_1: `%`(x0) + def $nunpack(I16_storagetype) = ?(I32_numtype) + def $nunpack{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_cunpack_before_fun_cunpack_case_13: `%`(storagetype) +def $vunpack(storagetype : storagetype) : vectype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_12: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_11: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_10: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_9: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_8: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_7: - `%`(I32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_0: - `%`(I32_storagetype) + def $vunpack(V128_storagetype) = ?(V128_vectype) + def $vunpack{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_cunpack: `%%`(storagetype, consttype?) +def $cunpack(storagetype : storagetype) : consttype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_0: - `%%`(I32_storagetype, ?(I32_consttype)) - + def $cunpack(I32_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_1: - `%%`(I64_storagetype, ?(I64_consttype)) - + def $cunpack(I64_storagetype) = ?(I64_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_2: - `%%`(F32_storagetype, ?(F32_consttype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_3: - `%%`(F64_storagetype, ?(F64_consttype)) - + def $cunpack(F32_storagetype) = ?(F32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_4: - `%%`(V128_storagetype, ?(V128_consttype)) - + def $cunpack(F64_storagetype) = ?(F64_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_5: - `%%`(I8_storagetype, ?(I32_consttype)) - + def $cunpack(V128_storagetype) = ?(V128_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_6: - `%%`(I16_storagetype, ?(I32_consttype)) - + def $cunpack(I8_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_7: - `%%`(I32_storagetype, ?($consttype_numtype($lunpack(I32_lanetype)))) - + def $cunpack(I16_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_8: - `%%`(I64_storagetype, ?($consttype_numtype($lunpack(I64_lanetype)))) - + def $cunpack(I32_storagetype) = ?($consttype_numtype($lunpack(I32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_9: - `%%`(F32_storagetype, ?($consttype_numtype($lunpack(F32_lanetype)))) - + def $cunpack(I64_storagetype) = ?($consttype_numtype($lunpack(I64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_10: - `%%`(F64_storagetype, ?($consttype_numtype($lunpack(F64_lanetype)))) - + def $cunpack(F32_storagetype) = ?($consttype_numtype($lunpack(F32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_11: - `%%`(I8_storagetype, ?($consttype_numtype($lunpack(I8_lanetype)))) - + def $cunpack(F64_storagetype) = ?($consttype_numtype($lunpack(F64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_12: - `%%`(I16_storagetype, ?($consttype_numtype($lunpack(I16_lanetype)))) - + def $cunpack(I8_storagetype) = ?($consttype_numtype($lunpack(I8_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_13{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_cunpack_before_fun_cunpack_case_13: `%`(x0) + 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 @@ -2080,85 +1799,110 @@ relation fun_diffrt: `%%%`(reftype, reftype, reftype) -- wf_reftype: `%`(REF_reftype(null_1#3?{null_1#3 <- `null_1?`}, ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_as_deftype_before_fun_as_deftype_case_1: `%`(typeuse) +def $as_deftype(typeuse : typeuse) : deftype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_0{rectype : rectype, n : n}: - `%`(_DEF_typeuse(rectype, n)) + 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 -relation fun_as_deftype: `%%`(typeuse, deftype?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_0{rectype : rectype, n : n}: - `%%`(_DEF_typeuse(rectype, n), ?(_DEF_deftype(rectype, n))) +rec { - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_1{x0 : typeuse}: - `%%`(x0, ?()) - -- ~ fun_as_deftype_before_fun_as_deftype_case_1: `%`(x0) +;; ../../../../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 -rec { + ;; ../../../../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.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 + 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: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: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: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: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: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 @@ -7559,30 +7303,28 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../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*, var_0 : deftype?}: + rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_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(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*, var_0 : deftype?}: + rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_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(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: @@ -7967,18 +7709,17 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*, var_0 : deftype?}: + 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*`}))) -- 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*`}))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_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*`}))) + -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) + -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:171.1-173.42 rule throw_ref{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: @@ -9304,7 +9045,7 @@ relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../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*, var_1 : funcidx*, var_0 : 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*, 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) -- wf_context: `%`(C) -- wf_context: `%`(C') @@ -9340,11 +9081,16 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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*`} = var_1) - -- 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 (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) + -- 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) @@ -9493,69 +9239,23 @@ relation fun_inv_signed_: `%%%`(N, 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 -relation fun_sx_before_fun_sx_case_7: `%`(storagetype) +def $sx(storagetype : storagetype) : sx?? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_6: - `%`(I16_storagetype) - + def $sx(I32_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_5: - `%`(I8_storagetype) - + def $sx(I64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_4: - `%`(V128_storagetype) - + def $sx(F32_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -relation fun_sx: `%%`(storagetype, sx??) + def $sx(F64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_0: - `%%`(I32_storagetype, ?(?())) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_1: - `%%`(I64_storagetype, ?(?())) - + def $sx(V128_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_2: - `%%`(F32_storagetype, ?(?())) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_3: - `%%`(F64_storagetype, ?(?())) - + def $sx(I8_storagetype) = ?(?(S_sx)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_4: - `%%`(V128_storagetype, ?(?())) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_5: - `%%`(I8_storagetype, ?(?(S_sx))) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_6: - `%%`(I16_storagetype, ?(?(S_sx))) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_7{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_sx_before_fun_sx_case_7: `%`(x0) + def $sx(I16_storagetype) = ?(?(S_sx)) + def $sx{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec relation fun_zero: `%%`(lanetype, lane_) @@ -10109,18 +9809,16 @@ relation fun_cunpacknum_: `%%%`(storagetype, lit_, lit_) `%%%`(V128_storagetype, c, c) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_cunpacknum__case_5{c : uN, var_0 : consttype?}: + rule fun_cunpacknum__case_5{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)))) - -- fun_cunpack: `%%`($storagetype_packtype(I8_packtype), var_0) - -- if (var_0 =/= ?()) - -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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)))) + -- if ($cunpack($storagetype_packtype(I8_packtype)) =/= ?()) + -- 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 - rule fun_cunpacknum__case_6{c : uN, var_0 : consttype?}: + rule fun_cunpacknum__case_6{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)))) - -- fun_cunpack: `%%`($storagetype_packtype(I16_packtype), var_0) - -- if (var_0 =/= ?()) - -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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)))) + -- if ($cunpack($storagetype_packtype(I16_packtype)) =/= ?()) + -- 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 fun_unop_: `%%%%`(numtype, unop_, num_, num_*) @@ -15508,66 +15206,101 @@ relation fun_unpackfield_: `%%%%`(storagetype, sx?, fieldval, 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 @@ -16714,7 +16447,7 @@ relation Step_pure: `%~>%`(instr*, 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_*, `var_0*` : uN*}: + rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*, `var_1*` : uN*, 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)]) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), i))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) @@ -16723,10 +16456,11 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) -- if ($proj_num__0(c) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0(var_0).0*{var_0 <- `var_0*`})) - -- if (|`var_0*`| = |`i*`|) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = var_0) + -- if (|`var_1*`| = |`i*`|) -- (if ($proj_lane__2(i) =/= ?()))*{i <- `i*`} - -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_0))*{var_0 <- `var_0*`, i <- `i*`} + -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_1))*{var_1 <- `var_1*`, i <- `i*`} + -- fun_prod: `%%`($proj_uN_0(var_1).0*{var_1 <- `var_1*`}, 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_, var_0 : vec_}: @@ -17294,7 +17028,7 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype, var_0 : sx??}: + rule `array.copy-le_0`{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)])) -- 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)) @@ -17312,9 +17046,8 @@ relation `Step_read_before_array.copy-gt`: `%`(config) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) - -- fun_sx: `%%`(zt_2, var_0) + -- 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)))) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx}: @@ -17389,16 +17122,15 @@ relation `Step_read_before_array.init_elem-succ`: `%`(config) ;; ../../../../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_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: + 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)])) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -17419,16 +17151,15 @@ relation `Step_read_before_array.init_data-num`: `%`(config) -- if (n = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: + 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)])) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -18157,33 +17888,30 @@ relation Step_read: `%~>%`(config, instr*) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : 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, var_0 : nat?}: + 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]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($proj_num__0(i) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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?, var_3 : nat?, `var_2*` : lit_*, var_1 : consttype?, `var_0*` : instr*}: + rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?, `var_1*` : lit_*, `var_0*` : 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)]), var_0^n{var_0 <- `var_0*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- (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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (var_3 =/= ?()) + -- if ($zsize(zt) =/= ?()) -- if ($proj_num__0(i) =/= ?()) - -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !(var_3)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- fun_zsize: `%%`(zt, var_3) - -- (fun_cunpacknum_: `%%%`(zt, c, var_2))^n{var_2 <- `var_2*`, c <- `c*`} - -- fun_cunpack: `%%`(zt, var_1) - -- (if (var_1 =/= ?()))^n{} - -- (fun_const: `%%%`(!(var_1), var_2, var_0))^n{var_2 <- `var_2*`, var_0 <- `var_0*`} + -- 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)]) + -- (fun_cunpacknum_: `%%%`(zt, c, var_1))^n{var_1 <- `var_1*`, c <- `c*`} + -- (if ($cunpack(zt) =/= ?()))^n{} + -- (fun_const: `%%%`(!($cunpack(zt)), var_1, var_0))^n{var_1 <- `var_1*`, var_0 <- `var_0*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -18298,7 +18026,7 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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, var_0 : sx??}: + 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) =/= ?()) @@ -18316,12 +18044,11 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) - -- fun_sx: `%%`(zt_2, var_0) + -- 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)))) ;; ../../../../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, var_0 : sx??}: + 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) =/= ?()) @@ -18339,9 +18066,8 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 (var_0 =/= ?()) - -- if (sx?{sx <- `sx?`} = !(var_0)) - -- fun_sx: `%%`(zt_2, var_0) + -- if ($sx(zt_2) =/= ?()) + -- if (sx?{sx <- `sx?`} = !($sx(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}: @@ -18407,16 +18133,15 @@ relation Step_read: `%~>%`(config, instr*) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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, var_0 : nat?}: + 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]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -18426,29 +18151,27 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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?, var_3 : nat?, var_2 : lit_, var_1 : consttype?, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 + (((!(var_3) : 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)]) + 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?, var_1 : lit_, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if (var_3 =/= ?()) + -- if ($zsize(zt) =/= ?()) -- 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_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 + (((!(var_3) : 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(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))) -- ~ `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 : (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- fun_zsize: `%%`(zt, var_3) - -- fun_cunpacknum_: `%%%`(zt, c, var_2) - -- fun_cunpack: `%%`(zt, var_1) - -- if (var_1 =/= ?()) - -- fun_const: `%%%`(!(var_1), var_2, var_0) + -- 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)]) + -- fun_cunpacknum_: `%%%`(zt, c, var_1) + -- if ($cunpack(zt) =/= ?()) + -- fun_const: `%%%`(!($cunpack(zt)), var_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rec { @@ -18507,18 +18230,17 @@ relation Step: `%~>%`(config, config) -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr*{instr <- `instr*`}), `%;%`_config(`%;%`_state(s', f''), instr'*{instr' <- `instr'*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:231.1-235.49 - rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_1 : deftype?, var_0 : state}: + rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_0 : state}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- if (var_1 =/= ?()) - -- Expand: `%~~%`(!(var_1), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) + -- 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 (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- fun_as_deftype: `%%`($tag(z, x).TYPE_taginst, var_1) -- fun_add_exninst: `%%%`(z, [exn], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:309.1-310.56 @@ -19044,28 +18766,33 @@ relation fun_allocexports: `%%%`(moduleinst, export*, exportinst*) ;; ../../../../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 - 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_13 : exportinst*, var_12 : (store, funcaddr*), `var_11*` : elemtype*, var_10 : (store, elemaddr*), var_9 : (store, dataaddr*), `var_8*` : tabletype*, var_7 : (store, tableaddr*), `var_6*` : memtype*, var_5 : (store, memaddr*), `var_4*` : globaltype*, var_3 : (store, globaladdr*), `var_2*` : tagtype*, var_1 : (store, tagaddr*), var_0 : deftype*}: + 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_18 : 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)) - -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_13) + -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) -- (if ($proj_uN_0(x#4).0 < |dt#15*{dt#15 <- `dt*`}|))*{x#4 <- `x*`} - -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_12) - -- if (|`var_11*`| = |`elemtype*`|) - -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_11))*{var_11 <- `var_11*`, elemtype#3 <- `elemtype*`} - -- fun_allocelems: `%%%%`(s_5, var_11*{var_11 <- `var_11*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_10) - -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_9) - -- if (|`var_8*`| = |`tabletype*`|) - -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_8))*{var_8 <- `var_8*`, tabletype#160 <- `tabletype*`} - -- fun_alloctables: `%%%%`(s_3, var_8*{var_8 <- `var_8*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_7) - -- if (|`var_6*`| = |`memtype*`|) - -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_6))*{var_6 <- `var_6*`, memtype#126 <- `memtype*`} - -- fun_allocmems: `%%%`(s_2, var_6*{var_6 <- `var_6*`}, var_5) - -- if (|`var_4*`| = |`globaltype*`|) - -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_4))*{var_4 <- `var_4*`, globaltype#126 <- `globaltype*`} - -- fun_allocglobals: `%%%%`(s_1, var_4*{var_4 <- `var_4*`}, val_G#2*{val_G#2 <- `val_G*`}, var_3) - -- if (|`var_2*`| = |`tagtype*`|) - -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_2))*{var_2 <- `var_2*`, tagtype#82 <- `tagtype*`} - -- fun_alloctags: `%%%`(s, var_2*{var_2 <- `var_2*`}, var_1) - -- fun_alloctypes: `%%`(type#4*{type#4 <- `type*`}, var_0) + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) + -- if (|`var_16*`| = |`elemtype*`|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) + -- if (|`var_13*`| = |`tabletype*`|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `tabletype*`} + -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) + -- if (|`var_11*`| = |`memtype*`|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- if (|`var_9*`| = |`globaltype*`|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `globaltype*`} + -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) + -- if (|`var_7*`| = |`tagtype*`|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `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) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(moduleinst) -- wf_store: `%`(s_1) @@ -19099,21 +18826,21 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* -- if (func#5*{func#5 <- `func*`} = FUNC_func(x#3, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#3 <- `x*`}) -- if (data#4*{data#4 <- `data*`} = DATA_data(byte#6*{byte#6 <- `byte*#112`}, datamode#112)*{`byte*#112` <- `byte**`, datamode#112 <- `datamode*`}) -- if (elem#6*{elem#6 <- `elem*`} = ELEM_elem(elemtype#2, expr_E#2*{expr_E#2 <- `expr_E*#2`}, elemmode#232)*{elemmode#232 <- `elemmode*`, elemtype#2 <- `elemtype*`, `expr_E*#2` <- `expr_E**`}) - -- if (aa_I#3*{aa_I#3 <- `aa_I*`} = $tagsxa(externaddr#2*{externaddr#2 <- `externaddr*`})) - -- if (ga_I#3*{ga_I#3 <- `ga_I*`} = $globalsxa(externaddr#3*{externaddr#3 <- `externaddr*`})) - -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`})) - -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = $tablesxa(externaddr#5*{externaddr#5 <- `externaddr*`})) - -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = $funcsxa(externaddr#6*{externaddr#6 <- `externaddr*`})) - -- if (dt#9*{dt#9 <- `dt*`} = var_0) + -- if (aa_I#3*{aa_I#3 <- `aa_I*`} = var_0) + -- if (ga_I#3*{ga_I#3 <- `ga_I*`} = var_1) + -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = var_2) + -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = var_3) + -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = var_4) + -- if (dt#9*{dt#9 <- `dt*`} = var_5) -- if (fa#3*{fa#3 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#6*{func#6 <- `func*`}|){}) - -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_1) - -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_3) - -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_5) - -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_7) - -- if ((s_5, da#2*{da#2 <- `da*`}) = var_9) - -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_10) - -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_12) - -- if (xi#2*{xi#2 <- `xi*`} = var_13) + -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_6) + -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_8) + -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_10) + -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_12) + -- if ((s_5, da#2*{da#2 <- `da*`}) = var_14) + -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_15) + -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_17) + -- if (xi#2*{xi#2 <- `xi*`} = var_18) -- if (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 @@ -19221,17 +18948,21 @@ relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_7*` : instr**, `var_6*` : instr**, var_5 : (store, moduleinst), var_4 : (state, ref**), var_3 : (state, ref*), var_2 : (state, val*), var_1 : deftype*, var_0 : deftype*}: + rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_11*` : instr**, `var_10*` : instr**, var_9 : (store, moduleinst), var_8 : (state, ref**), var_7 : (state, ref*), var_6 : (state, val*), var_5 : funcaddr*, var_4 : globaladdr*, var_3 : deftype*, 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?`}))) -- (if (i_E#2 < |elem#12*{elem#12 <- `elem*`}|))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} - -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_7))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} -- (if (i_D#2 < |data#11*{data#11 <- `data*`}|))^(i_D#2<|data#10*{data#10 <- `data*`}|){} - -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_6))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`} - -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_5) - -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_4) - -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_3) - -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_2) - -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_1) + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) + -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) + -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') @@ -19253,7 +18984,7 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (|`elemmode*`| = |`reftype*`|) -- (wf_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*`} -- (wf_start: `%`(START_start(x#6)))?{x#6 <- `x?`} - -- wf_moduleinst: `%`({TYPES var_0, TAGS [], GLOBALS $globalsxa(externaddr#8*{externaddr#8 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#9*{externaddr#9 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({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 []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#1)))^(i_D#1<|data#7*{data#7 <- `data*`}|){} @@ -19268,15 +18999,15 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (data#9*{data#9 <- `data*`} = DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`}) -- if (elem#10*{elem#10 <- `elem*`} = ELEM_elem(reftype#519, expr_E#4*{expr_E#4 <- `expr_E*#4`}, elemmode#239)*{elemmode#239 <- `elemmode*`, `expr_E*#4` <- `expr_E**`, reftype#519 <- `reftype*`}) -- if (start#8?{start#8 <- `start?`} = START_start(x#8)?{x#8 <- `x?`}) - -- if (moduleinst_0 = {TYPES var_1, TAGS [], GLOBALS $globalsxa(externaddr#11*{externaddr#11 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#12*{externaddr#12 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- if (moduleinst_0 = {TYPES var_3, TAGS [], GLOBALS var_4, MEMS [], TABLES [], FUNCS var_5 ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_2) - -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_3) - -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_4) + -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_6) + -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_7) + -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_8) -- if (z''' = `%;%`_state(s''', f)) - -- if ((s'''', moduleinst) = var_5) - -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_6^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`})) - -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_7^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`})) + -- if ((s'''', moduleinst) = var_9) + -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_10^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`})) + -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_11^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`})) -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -19501,156 +19232,240 @@ 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.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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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 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 relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule fun_ordered_case_0{`decl*` : decl*}: + rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: `%%`(decl#1*{decl#1 <- `decl*`}, true) - -- if ($importsd(decl#2*{decl#2 <- `decl*`}) = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) + -- if (var_0 = []) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule fun_ordered_case_1{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) @@ -22446,12 +22261,10 @@ grammar TfNmag(N : N) : fNmag ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod "inf" => INF_fNmag ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{var_0 : m} "nan" => NAN_fNmag(var_0) - -- fun_canon_: `%%`(N, var_0) + prod "nan" => NAN_fNmag($canon_(N)) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{n : n, var_0 : nat?} {{"nan:0x"} {n:Thexnum}} => NAN_fNmag(n) - -- if ((1 <= n) /\ (n < (2 ^ !(var_0)))) - -- fun_signif: `%%`(N, var_0) + 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 @@ -24071,22 +23884,33 @@ 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, var_1 : bool, 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*`})) + 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 var_1 - -- fun_ordered: `%%`(decl*{decl <- `decl*`}, var_1) + -- 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 diff --git a/spectec/test-middlend/specification.exp/11-alias-demut.il b/spectec/test-middlend/specification.exp/11-alias-demut.il index f527d52403..0f29962e0d 100644 --- a/spectec/test-middlend/specification.exp/11-alias-demut.il +++ b/spectec/test-middlend/specification.exp/11-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'#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 @@ -244,70 +252,32 @@ syntax i64 = iN syntax i128 = iN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_signif_before_fun_signif_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_1: - `%`(64) - +def $signif(N : N) : nat? ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_signif: `%%`(N, nat?) + def $signif(32) = ?(23) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_0: - `%%`(32, ?(23)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_1: - `%%`(64, ?(52)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_signif_before_fun_signif_case_2: `%`(x0) + def $signif(64) = ?(52) + def $signif{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_expon_before_fun_expon_case_2: `%`(N) +def $expon(N : N) : nat? ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_1: - `%`(64) - + def $expon(32) = ?(8) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_0: - `%`(32) + def $expon(64) = ?(11) + def $expon{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_expon: `%%`(N, nat?) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_0: - `%%`(32, ?(8)) - +def $M(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_1: - `%%`(64, ?(11)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_expon_before_fun_expon_case_2: `%`(x0) + def $M{N : nat}(N) = !($signif(N)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_M: `%%`(N, nat) +def $E(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_M_case_0{N : nat, var_0 : nat?}: - `%%`(N, !(var_0)) - -- if (var_0 =/= ?()) - -- fun_signif: `%%`(N, var_0) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_E: `%%`(N, nat) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_E_case_0{N : nat, var_0 : nat?}: - `%%`(N, !(var_0)) - -- if (var_0 =/= ?()) - -- fun_expon: `%%`(N, var_0) + def $E{N : nat}(N) = !($expon(N)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax exp = int @@ -322,28 +292,23 @@ syntax fNmag = ;; ../../../../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, var_1 : nat, var_0 : nat}: + rule fNmag_case_0{N : N, m : m, exp : exp}: `%%`(N, NORM_fNmag(m, exp)) - -- if ((m < (2 ^ var_0)) /\ ((((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= exp) /\ (exp <= (((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) - -- fun_E: `%%`(N, var_1) - -- fun_M: `%%`(N, var_0) + -- 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, var_1 : nat, var_0 : nat}: + rule fNmag_case_1{N : N, exp : exp, m : m}: `%%`(N, SUBNORM_fNmag(m)) - -- if ((m < (2 ^ var_0)) /\ (((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = exp)) - -- fun_E: `%%`(N, var_1) - -- fun_M: `%%`(N, var_0) + -- 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, var_0 : nat}: + rule fNmag_case_3{N : N, m : m}: `%%`(N, NAN_fNmag(m)) - -- if ((1 <= m) /\ (m < (2 ^ var_0))) - -- fun_M: `%%`(N, var_0) + -- if ((1 <= m) /\ (m < (2 ^ $M(N)))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax fN = @@ -390,12 +355,9 @@ relation fun_fone: `%%`(N, fN) -- wf_fN: `%%`(N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_canon_: `%%`(N, nat) +def $canon_(N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_canon__case_0{N : nat, var_0 : nat?}: - `%%`(N, (2 ^ (((!(var_0) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) - -- if (var_0 =/= ?()) - -- fun_signif: `%%`(N, var_0) + 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 @@ -584,66 +546,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 @@ -1495,95 +1492,35 @@ relation wf_moduletype: `%`(moduletype) -- (wf_externtype: `%`(`externtype*_0`))*{`externtype*_0` <- `externtype*_0`} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_IN_before_fun_IN_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_IN: `%%`(N, Inn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_0: - `%%`(32, ?(I32_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_1: - `%%`(64, ?(I64_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_IN_before_fun_IN_case_2: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_FN_before_fun_FN_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_FN: `%%`(N, Fnn?) +def $IN(N : N) : Inn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_0: - `%%`(32, ?(F32_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_1: - `%%`(64, ?(F64_Fnn)) - + def $IN(32) = ?(I32_Inn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_FN_before_fun_FN_case_2: `%`(x0) + def $IN(64) = ?(I64_Inn) + def $IN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_JN_before_fun_JN_case_4: `%`(N) +def $FN(N : N) : Fnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_3: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_2: - `%`(32) - + def $FN(32) = ?(F32_Fnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_1: - `%`(16) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_0: - `%`(8) + def $FN(64) = ?(F64_Fnn) + def $FN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_JN: `%%`(N, Jnn?) +def $JN(N : N) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_0: - `%%`(8, ?(I8_Jnn)) - + def $JN(8) = ?(I8_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_1: - `%%`(16, ?(I16_Jnn)) - + def $JN(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_2: - `%%`(32, ?(I32_Jnn)) - + def $JN(32) = ?(I32_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_3: - `%%`(64, ?(I64_Jnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_4{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_JN_before_fun_JN_case_4: `%`(x0) + 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 @@ -1624,69 +1561,23 @@ def $lsize(lanetype : lanetype) : nat def $lsize(I16_lanetype) = $psize(I16_packtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_zsize_before_fun_zsize_case_7: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_zsize: `%%`(storagetype, nat?) +def $zsize(storagetype : storagetype) : nat? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_0: - `%%`(I32_storagetype, ?($size(I32_numtype))) - + def $zsize(I32_storagetype) = ?($size(I32_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_1: - `%%`(I64_storagetype, ?($size(I64_numtype))) - + def $zsize(I64_storagetype) = ?($size(I64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_2: - `%%`(F32_storagetype, ?($size(F32_numtype))) - + def $zsize(F32_storagetype) = ?($size(F32_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_3: - `%%`(F64_storagetype, ?($size(F64_numtype))) - + def $zsize(F64_storagetype) = ?($size(F64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_4: - `%%`(V128_storagetype, ?($vsize(V128_vectype))) - + def $zsize(V128_storagetype) = ?($vsize(V128_vectype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_5: - `%%`(I8_storagetype, ?($psize(I8_packtype))) - + def $zsize(I8_storagetype) = ?($psize(I8_packtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_6: - `%%`(I16_storagetype, ?($psize(I16_packtype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_7{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_zsize_before_fun_zsize_case_7: `%`(x0) + 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 @@ -1704,69 +1595,31 @@ def $fsize(Fnn : Fnn) : nat def $fsize{Fnn : Fnn}(Fnn) = $size($numtype_Fnn(Fnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_isize_before_fun_inv_isize_case_2: `%`(nat) +def $inv_isize(nat : nat) : Inn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_1: - `%`(64) - + def $inv_isize(32) = ?(I32_Inn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_0: - `%`(32) + def $inv_isize(64) = ?(I64_Inn) + def $inv_isize{x0 : nat}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_isize: `%%`(nat, Inn?) +def $inv_jsize(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_0: - `%%`(32, ?(I32_Inn)) - + def $inv_jsize(8) = ?(I8_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_1: - `%%`(64, ?(I64_Inn)) - + def $inv_jsize(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_inv_isize_before_fun_inv_isize_case_2: `%`(x0) + 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 -relation fun_inv_jsize: `%%`(nat, Jnn?) +def $inv_fsize(nat : nat) : Fnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_0: - `%%`(8, ?(I8_Jnn)) - + def $inv_fsize(32) = ?(F32_Fnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_1: - `%%`(16, ?(I16_Jnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_2{n : nat, var_0 : Inn?}: - `%%`(n, $Jnn_addrtype(iter_val#1)?{iter_val#1 <- var_0}) - -- fun_inv_isize: `%%`(n, var_0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(nat) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_fsize: `%%`(nat, Fnn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_0: - `%%`(32, ?(F32_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_1: - `%%`(64, ?(F64_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(x0) + 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 @@ -1814,11 +1667,9 @@ def $jsizenn(Jnn : Jnn) : nat def $jsizenn{Jnn : Jnn}(Jnn) = $lsize($lanetype_Jnn(Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_jsizenn: `%%`(nat, Jnn?) +def $inv_jsizenn(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsizenn_case_0{n : nat, var_0 : Jnn?}: - `%%`(n, var_0) - -- fun_inv_jsize: `%%`(n, var_0) + def $inv_jsizenn{n : nat}(n) = $inv_jsize(n) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lunpack(lanetype : lanetype) : numtype @@ -1876,191 +1727,59 @@ relation fun_unpack: `%%`(storagetype, valtype) -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_nunpack_before_fun_nunpack_case_6: `%`(storagetype) +def $nunpack(storagetype : storagetype) : numtype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_5: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_4: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_2: - `%`(F32_storagetype) - + def $nunpack(I32_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_1: - `%`(I64_storagetype) - + def $nunpack(I64_storagetype) = ?(I64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_nunpack: `%%`(storagetype, numtype?) + def $nunpack(F32_storagetype) = ?(F32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_0: - `%%`(I32_storagetype, ?(I32_numtype)) - + def $nunpack(F64_storagetype) = ?(F64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_1: - `%%`(I64_storagetype, ?(I64_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_2: - `%%`(F32_storagetype, ?(F32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_3: - `%%`(F64_storagetype, ?(F64_numtype)) - + def $nunpack(I8_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_4: - `%%`(I8_storagetype, ?(I32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_5: - `%%`(I16_storagetype, ?(I32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_6{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_nunpack_before_fun_nunpack_case_6: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_vunpack_before_fun_vunpack_case_1: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_0: - `%`(V128_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_vunpack: `%%`(storagetype, vectype?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_0: - `%%`(V128_storagetype, ?(V128_vectype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_1{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_vunpack_before_fun_vunpack_case_1: `%`(x0) + def $nunpack(I16_storagetype) = ?(I32_numtype) + def $nunpack{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_cunpack_before_fun_cunpack_case_13: `%`(storagetype) +def $vunpack(storagetype : storagetype) : vectype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_12: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_11: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_10: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_9: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_8: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_7: - `%`(I32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_0: - `%`(I32_storagetype) + def $vunpack(V128_storagetype) = ?(V128_vectype) + def $vunpack{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_cunpack: `%%`(storagetype, consttype?) +def $cunpack(storagetype : storagetype) : consttype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_0: - `%%`(I32_storagetype, ?(I32_consttype)) - + def $cunpack(I32_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_1: - `%%`(I64_storagetype, ?(I64_consttype)) - + def $cunpack(I64_storagetype) = ?(I64_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_2: - `%%`(F32_storagetype, ?(F32_consttype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_3: - `%%`(F64_storagetype, ?(F64_consttype)) - + def $cunpack(F32_storagetype) = ?(F32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_4: - `%%`(V128_storagetype, ?(V128_consttype)) - + def $cunpack(F64_storagetype) = ?(F64_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_5: - `%%`(I8_storagetype, ?(I32_consttype)) - + def $cunpack(V128_storagetype) = ?(V128_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_6: - `%%`(I16_storagetype, ?(I32_consttype)) - + def $cunpack(I8_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_7: - `%%`(I32_storagetype, ?($consttype_numtype($lunpack(I32_lanetype)))) - + def $cunpack(I16_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_8: - `%%`(I64_storagetype, ?($consttype_numtype($lunpack(I64_lanetype)))) - + def $cunpack(I32_storagetype) = ?($consttype_numtype($lunpack(I32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_9: - `%%`(F32_storagetype, ?($consttype_numtype($lunpack(F32_lanetype)))) - + def $cunpack(I64_storagetype) = ?($consttype_numtype($lunpack(I64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_10: - `%%`(F64_storagetype, ?($consttype_numtype($lunpack(F64_lanetype)))) - + def $cunpack(F32_storagetype) = ?($consttype_numtype($lunpack(F32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_11: - `%%`(I8_storagetype, ?($consttype_numtype($lunpack(I8_lanetype)))) - + def $cunpack(F64_storagetype) = ?($consttype_numtype($lunpack(F64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_12: - `%%`(I16_storagetype, ?($consttype_numtype($lunpack(I16_lanetype)))) - + def $cunpack(I8_storagetype) = ?($consttype_numtype($lunpack(I8_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_13{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_cunpack_before_fun_cunpack_case_13: `%`(x0) + 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 @@ -2080,85 +1799,110 @@ relation fun_diffrt: `%%%`(reftype, reftype, reftype) -- wf_reftype: `%`(REF_reftype(null_1#3?{null_1#3 <- `null_1?`}, ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_as_deftype_before_fun_as_deftype_case_1: `%`(typeuse) +def $as_deftype(typeuse : typeuse) : deftype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_0{rectype : rectype, n : n}: - `%`(_DEF_typeuse(rectype, n)) + 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 -relation fun_as_deftype: `%%`(typeuse, deftype?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_0{rectype : rectype, n : n}: - `%%`(_DEF_typeuse(rectype, n), ?(_DEF_deftype(rectype, n))) +rec { - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_1{x0 : typeuse}: - `%%`(x0, ?()) - -- ~ fun_as_deftype_before_fun_as_deftype_case_1: `%`(x0) +;; ../../../../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 -rec { + ;; ../../../../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.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 + 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: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: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: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: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: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 @@ -7559,30 +7303,28 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../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*, var_0 : deftype?}: + rule catch{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_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(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*, var_0 : deftype?}: + rule catch_ref{C : context, x : idx, l : labelidx, `t*` : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t*{t <- `t*`}), `%`_resulttype([]))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_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(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: @@ -7967,18 +7709,17 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_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*, var_0 : deftype?}: + 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*`}))) -- 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*`}))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_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*`}))) + -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) + -- 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*`}))) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec:171.1-173.42 rule throw_ref{C : context, `t_1*` : valtype*, `t_2*` : valtype*}: @@ -9304,7 +9045,7 @@ relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../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*, var_1 : funcidx*, var_0 : 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*, 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) -- wf_context: `%`(C) -- wf_context: `%`(C') @@ -9340,11 +9081,16 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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*`} = var_1) - -- 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 (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) + -- 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) @@ -9493,69 +9239,23 @@ relation fun_inv_signed_: `%%%`(N, 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 -relation fun_sx_before_fun_sx_case_7: `%`(storagetype) +def $sx(storagetype : storagetype) : sx?? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_6: - `%`(I16_storagetype) - + def $sx(I32_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_5: - `%`(I8_storagetype) - + def $sx(I64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_4: - `%`(V128_storagetype) - + def $sx(F32_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -relation fun_sx: `%%`(storagetype, sx??) + def $sx(F64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_0: - `%%`(I32_storagetype, ?(?())) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_1: - `%%`(I64_storagetype, ?(?())) - + def $sx(V128_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_2: - `%%`(F32_storagetype, ?(?())) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_3: - `%%`(F64_storagetype, ?(?())) - + def $sx(I8_storagetype) = ?(?(S_sx)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_4: - `%%`(V128_storagetype, ?(?())) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_5: - `%%`(I8_storagetype, ?(?(S_sx))) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_6: - `%%`(I16_storagetype, ?(?(S_sx))) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_7{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_sx_before_fun_sx_case_7: `%`(x0) + def $sx(I16_storagetype) = ?(?(S_sx)) + def $sx{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec relation fun_zero: `%%`(lanetype, lane_) @@ -10109,18 +9809,16 @@ relation fun_cunpacknum_: `%%%`(storagetype, lit_, lit_) `%%%`(V128_storagetype, c, c) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_cunpacknum__case_5{c : uN, var_0 : consttype?}: + rule fun_cunpacknum__case_5{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)))) - -- fun_cunpack: `%%`($storagetype_packtype(I8_packtype), var_0) - -- if (var_0 =/= ?()) - -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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)))) + -- if ($cunpack($storagetype_packtype(I8_packtype)) =/= ?()) + -- 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 - rule fun_cunpacknum__case_6{c : uN, var_0 : consttype?}: + rule fun_cunpacknum__case_6{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)))) - -- fun_cunpack: `%%`($storagetype_packtype(I16_packtype), var_0) - -- if (var_0 =/= ?()) - -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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)))) + -- if ($cunpack($storagetype_packtype(I16_packtype)) =/= ?()) + -- 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 fun_unop_: `%%%%`(numtype, unop_, num_, num_*) @@ -15508,66 +15206,101 @@ relation fun_unpackfield_: `%%%%`(storagetype, sx?, fieldval, 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 @@ -16714,7 +16447,7 @@ relation Step_pure: `%~>%`(instr*, 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_*, `var_0*` : uN*}: + rule vtestop{c_1 : vec_, Jnn : Jnn, M : M, c : num_, `i*` : lane_*, `var_1*` : uN*, 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)]) -- (wf_lane_: `%%`($lanetype(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))), i))*{i <- `i*`} -- wf_instr: `%`(VCONST_instr(V128_vectype, c_1)) @@ -16723,10 +16456,11 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M))) -- if (i*{i <- `i*`} = $lanes_(`%X%`_shape($lanetype_Jnn(Jnn), `%`_dim(M)), c_1)) -- if ($proj_num__0(c) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0(var_0).0*{var_0 <- `var_0*`})) - -- if (|`var_0*`| = |`i*`|) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = var_0) + -- if (|`var_1*`| = |`i*`|) -- (if ($proj_lane__2(i) =/= ?()))*{i <- `i*`} - -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_0))*{var_0 <- `var_0*`, i <- `i*`} + -- (fun_inez_: `%%%`($jsizenn(Jnn), !($proj_lane__2(i)), var_1))*{var_1 <- `var_1*`, i <- `i*`} + -- fun_prod: `%%`($proj_uN_0(var_1).0*{var_1 <- `var_1*`}, 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_, var_0 : vec_}: @@ -17294,7 +17028,7 @@ relation `Step_read_before_array.copy-le`: `%`(config) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx, `sx?` : sx?, `mut?` : mut?, zt_2 : storagetype, var_0 : sx??}: + rule `array.copy-le_0`{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)])) -- 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)) @@ -17312,9 +17046,8 @@ relation `Step_read_before_array.copy-gt`: `%`(config) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) - -- fun_sx: `%%`(zt_2, var_0) + -- 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)))) ;; ../../../../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_, n : n, x_1 : idx, x_2 : idx}: @@ -17389,16 +17122,15 @@ relation `Step_read_before_array.init_elem-succ`: `%`(config) ;; ../../../../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_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: + 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)])) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -17419,16 +17151,15 @@ relation `Step_read_before_array.init_data-num`: `%`(config) -- if (n = 0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec - rule `array.init_data-oob2_1`{z : state, a : addr, i : num_, j : num_, n : n, x : idx, y : idx, `mut?` : mut?, zt : storagetype, var_0 : nat?}: + 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)])) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -18157,33 +17888,30 @@ relation Step_read: `%~>%`(config, instr*) -- if (ref^n{ref <- `ref*`} = $elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : 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, var_0 : nat?}: + 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]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($proj_num__0(i) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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?, var_3 : nat?, `var_2*` : lit_*, var_1 : consttype?, `var_0*` : instr*}: + rule `array.new_data-num`{z : state, i : num_, n : n, x : idx, y : idx, zt : storagetype, `c*` : lit_*, `mut?` : mut?, `var_1*` : lit_*, `var_0*` : 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)]), var_0^n{var_0 <- `var_0*`} ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(n))]) -- (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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) - -- if (var_3 =/= ?()) + -- if ($zsize(zt) =/= ?()) -- if ($proj_num__0(i) =/= ?()) - -- if ($concatn_(syntax byte, $zbytes_(zt, c)^n{c <- `c*`}, (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((n * !(var_3)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- fun_zsize: `%%`(zt, var_3) - -- (fun_cunpacknum_: `%%%`(zt, c, var_2))^n{var_2 <- `var_2*`, c <- `c*`} - -- fun_cunpack: `%%`(zt, var_1) - -- (if (var_1 =/= ?()))^n{} - -- (fun_const: `%%%`(!(var_1), var_2, var_0))^n{var_2 <- `var_2*`, var_0 <- `var_0*`} + -- 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)]) + -- (fun_cunpacknum_: `%%%`(zt, c, var_1))^n{var_1 <- `var_1*`, c <- `c*`} + -- (if ($cunpack(zt) =/= ?()))^n{} + -- (fun_const: `%%%`(!($cunpack(zt)), var_1, var_0))^n{var_1 <- `var_1*`, var_0 <- `var_0*`} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule `array.get-null`{z : state, i : num_, `sx?` : sx?, x : idx}: @@ -18298,7 +18026,7 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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, var_0 : sx??}: + 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) =/= ?()) @@ -18316,12 +18044,11 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx?{sx <- `sx?`} = !(var_0))) - -- fun_sx: `%%`(zt_2, var_0) + -- 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)))) ;; ../../../../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, var_0 : sx??}: + 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) =/= ?()) @@ -18339,9 +18066,8 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt_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 (var_0 =/= ?()) - -- if (sx?{sx <- `sx?`} = !(var_0)) - -- fun_sx: `%%`(zt_2, var_0) + -- if ($sx(zt_2) =/= ?()) + -- if (sx?{sx <- `sx?`} = !($sx(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}: @@ -18407,16 +18133,15 @@ relation Step_read: `%~>%`(config, instr*) -- if (($proj_uN_0(!($proj_num__0(i))).0 + n) > |$arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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, var_0 : nat?}: + 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]) -- 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))) -- Expand: `%~~%`($type(z, x), ARRAY_comptype(`%%`_fieldtype(mut?{mut <- `mut?`}, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -18426,29 +18151,27 @@ relation Step_read: `%~>%`(config, instr*) -- if (n = 0) ;; ../../../../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?, var_3 : nat?, var_2 : lit_, var_1 : consttype?, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 + (((!(var_3) : 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)]) + 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?, var_1 : lit_, var_0 : 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)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if (var_3 =/= ?()) + -- if ($zsize(zt) =/= ?()) -- 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_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 + (((!(var_3) : 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(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))) -- ~ `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 : (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- fun_zsize: `%%`(zt, var_3) - -- fun_cunpacknum_: `%%%`(zt, c, var_2) - -- fun_cunpack: `%%`(zt, var_1) - -- if (var_1 =/= ?()) - -- fun_const: `%%%`(!(var_1), var_2, var_0) + -- 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)]) + -- fun_cunpacknum_: `%%%`(zt, c, var_1) + -- if ($cunpack(zt) =/= ?()) + -- fun_const: `%%%`(!($cunpack(zt)), var_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rec { @@ -18507,18 +18230,17 @@ relation Step: `%~>%`(config, config) -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr*{instr <- `instr*`}), `%;%`_config(`%;%`_state(s', f''), instr'*{instr' <- `instr'*`})) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:231.1-235.49 - rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_1 : deftype?, var_0 : state}: + rule throw{z : state, n : n, `val*` : val*, x : idx, exn : exninst, a : addr, `t*` : valtype*, var_0 : state}: `%~>%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)]), `%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_config: `%`(`%;%`_config(z, $instr_val(val)^n{val <- `val*`} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) -- if ($proj_uN_0(x).0 < |$tagaddr(z)|) -- wf_exninst: `%`({TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- if (var_1 =/= ?()) - -- Expand: `%~~%`(!(var_1), `FUNC%->%`_comptype(`%`_resulttype(t^n{t <- `t*`}), `%`_resulttype([]))) + -- 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 (exn = {TAG $tagaddr(z)[$proj_uN_0(x).0], FIELDS val^n{val <- `val*`}}) - -- fun_as_deftype: `%%`($tag(z, x).TYPE_taginst, var_1) -- fun_add_exninst: `%%%`(z, [exn], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:309.1-310.56 @@ -19044,28 +18766,33 @@ relation fun_allocexports: `%%%`(moduleinst, export*, exportinst*) ;; ../../../../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 - 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_13 : exportinst*, var_12 : (store, funcaddr*), `var_11*` : elemtype*, var_10 : (store, elemaddr*), var_9 : (store, dataaddr*), `var_8*` : tabletype*, var_7 : (store, tableaddr*), `var_6*` : memtype*, var_5 : (store, memaddr*), `var_4*` : globaltype*, var_3 : (store, globaladdr*), `var_2*` : tagtype*, var_1 : (store, tagaddr*), var_0 : deftype*}: + 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_18 : 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)) - -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_13) + -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) -- (if ($proj_uN_0(x#4).0 < |dt#15*{dt#15 <- `dt*`}|))*{x#4 <- `x*`} - -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_12) - -- if (|`var_11*`| = |`elemtype*`|) - -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_11))*{var_11 <- `var_11*`, elemtype#3 <- `elemtype*`} - -- fun_allocelems: `%%%%`(s_5, var_11*{var_11 <- `var_11*`}, ref_E#2*{ref_E#2 <- `ref_E*#2`}*{`ref_E*#2` <- `ref_E**`}, var_10) - -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_9) - -- if (|`var_8*`| = |`tabletype*`|) - -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_8))*{var_8 <- `var_8*`, tabletype#160 <- `tabletype*`} - -- fun_alloctables: `%%%%`(s_3, var_8*{var_8 <- `var_8*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_7) - -- if (|`var_6*`| = |`memtype*`|) - -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_6))*{var_6 <- `var_6*`, memtype#126 <- `memtype*`} - -- fun_allocmems: `%%%`(s_2, var_6*{var_6 <- `var_6*`}, var_5) - -- if (|`var_4*`| = |`globaltype*`|) - -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_4))*{var_4 <- `var_4*`, globaltype#126 <- `globaltype*`} - -- fun_allocglobals: `%%%%`(s_1, var_4*{var_4 <- `var_4*`}, val_G#2*{val_G#2 <- `val_G*`}, var_3) - -- if (|`var_2*`| = |`tagtype*`|) - -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_2))*{var_2 <- `var_2*`, tagtype#82 <- `tagtype*`} - -- fun_alloctags: `%%%`(s, var_2*{var_2 <- `var_2*`}, var_1) - -- fun_alloctypes: `%%`(type#4*{type#4 <- `type*`}, var_0) + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) + -- if (|`var_16*`| = |`elemtype*`|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) + -- if (|`var_13*`| = |`tabletype*`|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `tabletype*`} + -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) + -- if (|`var_11*`| = |`memtype*`|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- if (|`var_9*`| = |`globaltype*`|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `globaltype*`} + -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) + -- if (|`var_7*`| = |`tagtype*`|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `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) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(moduleinst) -- wf_store: `%`(s_1) @@ -19099,21 +18826,21 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* -- if (func#5*{func#5 <- `func*`} = FUNC_func(x#3, local#3*{local#3 <- `local*#84`}, expr_F#2)*{expr_F#2 <- `expr_F*`, `local*#84` <- `local**`, x#3 <- `x*`}) -- if (data#4*{data#4 <- `data*`} = DATA_data(byte#6*{byte#6 <- `byte*#112`}, datamode#112)*{`byte*#112` <- `byte**`, datamode#112 <- `datamode*`}) -- if (elem#6*{elem#6 <- `elem*`} = ELEM_elem(elemtype#2, expr_E#2*{expr_E#2 <- `expr_E*#2`}, elemmode#232)*{elemmode#232 <- `elemmode*`, elemtype#2 <- `elemtype*`, `expr_E*#2` <- `expr_E**`}) - -- if (aa_I#3*{aa_I#3 <- `aa_I*`} = $tagsxa(externaddr#2*{externaddr#2 <- `externaddr*`})) - -- if (ga_I#3*{ga_I#3 <- `ga_I*`} = $globalsxa(externaddr#3*{externaddr#3 <- `externaddr*`})) - -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = $memsxa(externaddr#4*{externaddr#4 <- `externaddr*`})) - -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = $tablesxa(externaddr#5*{externaddr#5 <- `externaddr*`})) - -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = $funcsxa(externaddr#6*{externaddr#6 <- `externaddr*`})) - -- if (dt#9*{dt#9 <- `dt*`} = var_0) + -- if (aa_I#3*{aa_I#3 <- `aa_I*`} = var_0) + -- if (ga_I#3*{ga_I#3 <- `ga_I*`} = var_1) + -- if (ma_I#3*{ma_I#3 <- `ma_I*`} = var_2) + -- if (ta_I#3*{ta_I#3 <- `ta_I*`} = var_3) + -- if (fa_I#3*{fa_I#3 <- `fa_I*`} = var_4) + -- if (dt#9*{dt#9 <- `dt*`} = var_5) -- if (fa#3*{fa#3 <- `fa*`} = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func#6*{func#6 <- `func*`}|){}) - -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_1) - -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_3) - -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_5) - -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_7) - -- if ((s_5, da#2*{da#2 <- `da*`}) = var_9) - -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_10) - -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_12) - -- if (xi#2*{xi#2 <- `xi*`} = var_13) + -- if ((s_1, aa#3*{aa#3 <- `aa*`}) = var_6) + -- if ((s_2, ga#3*{ga#3 <- `ga*`}) = var_8) + -- if ((s_3, ma#3*{ma#3 <- `ma*`}) = var_10) + -- if ((s_4, ta#3*{ta#3 <- `ta*`}) = var_12) + -- if ((s_5, da#2*{da#2 <- `da*`}) = var_14) + -- if ((s_6, ea#2*{ea#2 <- `ea*`}) = var_15) + -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_17) + -- if (xi#2*{xi#2 <- `xi*`} = var_18) -- if (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 @@ -19221,17 +18948,21 @@ relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_7*` : instr**, `var_6*` : instr**, var_5 : (store, moduleinst), var_4 : (state, ref**), var_3 : (state, ref*), var_2 : (state, val*), var_1 : deftype*, var_0 : deftype*}: + rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_11*` : instr**, `var_10*` : instr**, var_9 : (store, moduleinst), var_8 : (state, ref**), var_7 : (state, ref*), var_6 : (state, val*), var_5 : funcaddr*, var_4 : globaladdr*, var_3 : deftype*, 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?`}))) -- (if (i_E#2 < |elem#12*{elem#12 <- `elem*`}|))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} - -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_7))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} -- (if (i_D#2 < |data#11*{data#11 <- `data*`}|))^(i_D#2<|data#10*{data#10 <- `data*`}|){} - -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_6))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`} - -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_5) - -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_4) - -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_3) - -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_2) - -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_1) + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) + -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) + -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') @@ -19253,7 +18984,7 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (|`elemmode*`| = |`reftype*`|) -- (wf_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*`} -- (wf_start: `%`(START_start(x#6)))?{x#6 <- `x?`} - -- wf_moduleinst: `%`({TYPES var_0, TAGS [], GLOBALS $globalsxa(externaddr#8*{externaddr#8 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#9*{externaddr#9 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#2)^(i_F#2<|func#9*{func#9 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- wf_moduleinst: `%`({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 []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#1)))^(i_D#1<|data#7*{data#7 <- `data*`}|){} @@ -19268,15 +18999,15 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (data#9*{data#9 <- `data*`} = DATA_data(byte#9*{byte#9 <- `byte*#119`}, datamode#118)*{`byte*#119` <- `byte**`, datamode#118 <- `datamode*`}) -- if (elem#10*{elem#10 <- `elem*`} = ELEM_elem(reftype#519, expr_E#4*{expr_E#4 <- `expr_E*#4`}, elemmode#239)*{elemmode#239 <- `elemmode*`, `expr_E*#4` <- `expr_E**`, reftype#519 <- `reftype*`}) -- if (start#8?{start#8 <- `start?`} = START_start(x#8)?{x#8 <- `x?`}) - -- if (moduleinst_0 = {TYPES var_1, TAGS [], GLOBALS $globalsxa(externaddr#11*{externaddr#11 <- `externaddr*`}), MEMS [], TABLES [], FUNCS $funcsxa(externaddr#12*{externaddr#12 <- `externaddr*`}) ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) + -- if (moduleinst_0 = {TYPES var_3, TAGS [], GLOBALS var_4, MEMS [], TABLES [], FUNCS var_5 ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func#11*{func#11 <- `func*`}|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_2) - -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_3) - -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_4) + -- if ((z', val_G#4*{val_G#4 <- `val_G*`}) = var_6) + -- if ((z'', ref_T#4*{ref_T#4 <- `ref_T*`}) = var_7) + -- if ((z''', ref_E#4*{ref_E#4 <- `ref_E*#4`}*{`ref_E*#4` <- `ref_E**`}) = var_8) -- if (z''' = `%;%`_state(s''', f)) - -- if ((s'''', moduleinst) = var_5) - -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_6^(i_D#2<|data#10*{data#10 <- `data*`}|){var_6 <- `var_6*`})) - -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_7^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_7 <- `var_7*`})) + -- if ((s'''', moduleinst) = var_9) + -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_10^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`})) + -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_11^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`})) -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -19501,156 +19232,240 @@ 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.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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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: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 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 relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule fun_ordered_case_0{`decl*` : decl*}: + rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: `%%`(decl#1*{decl#1 <- `decl*`}, true) - -- if ($importsd(decl#2*{decl#2 <- `decl*`}) = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) + -- if (var_0 = []) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule fun_ordered_case_1{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) @@ -22446,12 +22261,10 @@ grammar TfNmag(N : N) : fNmag ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod "inf" => INF_fNmag ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{var_0 : m} "nan" => NAN_fNmag(var_0) - -- fun_canon_: `%%`(N, var_0) + prod "nan" => NAN_fNmag($canon_(N)) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{n : n, var_0 : nat?} {{"nan:0x"} {n:Thexnum}} => NAN_fNmag(n) - -- if ((1 <= n) /\ (n < (2 ^ !(var_0)))) - -- fun_signif: `%%`(N, var_0) + 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 @@ -24071,22 +23884,33 @@ 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, var_1 : bool, 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*`})) + 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 var_1 - -- fun_ordered: `%%`(decl*{decl <- `decl*`}, var_1) + -- 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 diff --git a/spectec/test-middlend/specification.exp/12-improve-ids.il b/spectec/test-middlend/specification.exp/12-improve-ids.il index 950ef0df88..a73494eee4 100644 --- a/spectec/test-middlend/specification.exp/12-improve-ids.il +++ b/spectec/test-middlend/specification.exp/12-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 @@ -244,70 +252,32 @@ syntax i64 = iN syntax i128 = iN ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_signif_before_fun_signif_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_signif: `%%`(N, nat?) - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_0: - `%%`(32, ?(23)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_1: - `%%`(64, ?(52)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_signif_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_signif_before_fun_signif_case_2: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_expon_before_fun_expon_case_2: `%`(N) +def $signif(v_N : N) : nat? ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_1: - `%`(64) - + def $signif(32) = ?(23) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_0: - `%`(32) + def $signif(64) = ?(52) + def $signif{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_expon: `%%`(N, nat?) +def $expon(v_N : N) : nat? ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_0: - `%%`(32, ?(8)) - + def $expon(32) = ?(8) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_1: - `%%`(64, ?(11)) - - ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_expon_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_expon_before_fun_expon_case_2: `%`(x0) + def $expon(64) = ?(11) + def $expon{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_M: `%%`(N, nat) +def $fun_M(v_N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_M_case_0{v_N : nat, var_0 : nat?}: - `%%`(v_N, !(var_0)) - -- if (var_0 =/= ?()) - -- fun_signif: `%%`(v_N, var_0) + def $fun_M{v_N : nat}(v_N) = !($signif(v_N)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_E: `%%`(N, nat) +def $E(v_N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_E_case_0{v_N : nat, var_0 : nat?}: - `%%`(v_N, !(var_0)) - -- if (var_0 =/= ?()) - -- fun_expon: `%%`(v_N, var_0) + def $E{v_N : nat}(v_N) = !($expon(v_N)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax exp = int @@ -322,28 +292,23 @@ syntax fNmag = ;; ../../../../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{v_N : N, v_m : m, v_exp : exp, var_1 : nat, var_0 : nat}: + rule fNmag_case_0{v_N : N, v_m : m, v_exp : exp}: `%%`(v_N, NORM_fNmag(v_m, v_exp)) - -- if ((v_m < (2 ^ var_0)) /\ ((((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= v_exp) /\ (v_exp <= (((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int) - (1 : nat <:> int))))) - -- fun_E: `%%`(v_N, var_1) - -- fun_M: `%%`(v_N, var_0) + -- if ((v_m < (2 ^ $fun_M(v_N))) /\ ((((2 : nat <:> int) - ((2 ^ ((($E(v_N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) <= v_exp) /\ (v_exp <= (((2 ^ ((($E(v_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{v_N : N, v_exp : exp, v_m : m, var_1 : nat, var_0 : nat}: + rule fNmag_case_1{v_N : N, v_exp : exp, v_m : m}: `%%`(v_N, SUBNORM_fNmag(v_m)) - -- if ((v_m < (2 ^ var_0)) /\ (((2 : nat <:> int) - ((2 ^ (((var_1 : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = v_exp)) - -- fun_E: `%%`(v_N, var_1) - -- fun_M: `%%`(v_N, var_0) + -- if ((v_m < (2 ^ $fun_M(v_N))) /\ (((2 : nat <:> int) - ((2 ^ ((($E(v_N) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> int)) = v_exp)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec rule fNmag_case_2{v_N : N}: `%%`(v_N, INF_fNmag) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fNmag_case_3{v_N : N, v_m : m, var_0 : nat}: + rule fNmag_case_3{v_N : N, v_m : m}: `%%`(v_N, NAN_fNmag(v_m)) - -- if ((1 <= v_m) /\ (v_m < (2 ^ var_0))) - -- fun_M: `%%`(v_N, var_0) + -- if ((1 <= v_m) /\ (v_m < (2 ^ $fun_M(v_N)))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax fN = @@ -390,12 +355,9 @@ relation fun_fone: `%%`(N, fN) -- wf_fN: `%%`(v_N, POS_fN(NORM_fNmag(1, (0 : nat <:> int)))) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec -relation fun_canon_: `%%`(N, nat) +def $canon_(v_N : N) : nat ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec - rule fun_canon__case_0{v_N : nat, var_0 : nat?}: - `%%`(v_N, (2 ^ (((!(var_0) : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) - -- if (var_0 =/= ?()) - -- fun_signif: `%%`(v_N, var_0) + def $canon_{v_N : nat}(v_N) = (2 ^ (((!($signif(v_N)) : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) ;; ../../../../specification/wasm-3.0/1.1-syntax.values.spectec syntax vN = uN @@ -584,66 +546,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 @@ -1495,95 +1492,35 @@ relation wf_moduletype: `%`(moduletype) -- (wf_externtype: `%`(externtype_lst_0))*{externtype_lst_0 <- externtype_lst_0} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_IN_before_fun_IN_case_2: `%`(N) +def $IN(v_N : N) : Inn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_1: - `%`(64) - + def $IN(32) = ?(I32_Inn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_IN: `%%`(N, Inn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_0: - `%%`(32, ?(I32_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_1: - `%%`(64, ?(I64_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_IN_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_IN_before_fun_IN_case_2: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_FN_before_fun_FN_case_2: `%`(N) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_1: - `%`(64) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_FN: `%%`(N, Fnn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_0: - `%%`(32, ?(F32_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_1: - `%%`(64, ?(F64_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_FN_case_2{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_FN_before_fun_FN_case_2: `%`(x0) + def $IN(64) = ?(I64_Inn) + def $IN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_JN_before_fun_JN_case_4: `%`(N) +def $FN(v_N : N) : Fnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_3: - `%`(64) - + def $FN(32) = ?(F32_Fnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_2: - `%`(32) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_1: - `%`(16) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_0: - `%`(8) + def $FN(64) = ?(F64_Fnn) + def $FN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_JN: `%%`(N, Jnn?) +def $JN(v_N : N) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_0: - `%%`(8, ?(I8_Jnn)) - + def $JN(8) = ?(I8_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_1: - `%%`(16, ?(I16_Jnn)) - + def $JN(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_2: - `%%`(32, ?(I32_Jnn)) - + def $JN(32) = ?(I32_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_3: - `%%`(64, ?(I64_Jnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_JN_case_4{x0 : N}: - `%%`(x0, ?()) - -- ~ fun_JN_before_fun_JN_case_4: `%`(x0) + def $JN(64) = ?(I64_Jnn) + def $JN{x0 : N}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $size(v_numtype : numtype) : nat @@ -1624,69 +1561,23 @@ def $lsize(v_lanetype : lanetype) : nat def $lsize(I16_lanetype) = $psize(I16_packtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_zsize_before_fun_zsize_case_7: `%`(storagetype) +def $zsize(v_storagetype : storagetype) : nat? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_6: - `%`(I16_storagetype) - + def $zsize(I32_storagetype) = ?($size(I32_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_5: - `%`(I8_storagetype) - + def $zsize(I64_storagetype) = ?($size(I64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_4: - `%`(V128_storagetype) - + def $zsize(F32_storagetype) = ?($size(F32_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_3: - `%`(F64_storagetype) - + def $zsize(F64_storagetype) = ?($size(F64_numtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_2: - `%`(F32_storagetype) - + def $zsize(V128_storagetype) = ?($vsize(V128_vectype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_1: - `%`(I64_storagetype) - + def $zsize(I8_storagetype) = ?($psize(I8_packtype)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_zsize: `%%`(storagetype, nat?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_0: - `%%`(I32_storagetype, ?($size(I32_numtype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_1: - `%%`(I64_storagetype, ?($size(I64_numtype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_2: - `%%`(F32_storagetype, ?($size(F32_numtype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_3: - `%%`(F64_storagetype, ?($size(F64_numtype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_4: - `%%`(V128_storagetype, ?($vsize(V128_vectype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_5: - `%%`(I8_storagetype, ?($psize(I8_packtype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_6: - `%%`(I16_storagetype, ?($psize(I16_packtype))) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_zsize_case_7{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_zsize_before_fun_zsize_case_7: `%`(x0) + def $zsize(I16_storagetype) = ?($psize(I16_packtype)) + def $zsize{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $isize(v_Inn : Inn) : nat @@ -1704,69 +1595,31 @@ def $fsize(v_Fnn : Fnn) : nat def $fsize{v_Fnn : Fnn}(v_Fnn) = $size($numtype_Fnn(v_Fnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_isize_before_fun_inv_isize_case_2: `%`(nat) +def $inv_isize(nat : nat) : Inn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_1: - `%`(64) - + def $inv_isize(32) = ?(I32_Inn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_isize: `%%`(nat, Inn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_0: - `%%`(32, ?(I32_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_1: - `%%`(64, ?(I64_Inn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_isize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_inv_isize_before_fun_inv_isize_case_2: `%`(x0) + def $inv_isize(64) = ?(I64_Inn) + def $inv_isize{x0 : nat}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_jsize: `%%`(nat, Jnn?) +def $inv_jsize(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_0: - `%%`(8, ?(I8_Jnn)) - + def $inv_jsize(8) = ?(I8_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_1: - `%%`(16, ?(I16_Jnn)) - + def $inv_jsize(16) = ?(I16_Jnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsize_case_2{v_n : nat, var_0 : Inn?}: - `%%`(v_n, $Jnn_addrtype(iter_val#1)?{iter_val#1 <- var_0}) - -- fun_inv_isize: `%%`(v_n, var_0) + 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 -relation fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(nat) +def $inv_fsize(nat : nat) : Fnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_1: - `%`(64) - + def $inv_fsize(32) = ?(F32_Fnn) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_0: - `%`(32) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_fsize: `%%`(nat, Fnn?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_0: - `%%`(32, ?(F32_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_1: - `%%`(64, ?(F64_Fnn)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_fsize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_inv_fsize_before_fun_inv_fsize_case_2: `%`(x0) + def $inv_fsize(64) = ?(F64_Fnn) + def $inv_fsize{x0 : nat}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $sizenn(v_numtype : numtype) : nat @@ -1814,11 +1667,9 @@ def $jsizenn(v_Jnn : Jnn) : nat def $jsizenn{v_Jnn : Jnn}(v_Jnn) = $lsize($lanetype_Jnn(v_Jnn)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_inv_jsizenn: `%%`(nat, Jnn?) +def $inv_jsizenn(nat : nat) : Jnn? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_inv_jsizenn_case_0{v_n : nat, var_0 : Jnn?}: - `%%`(v_n, var_0) - -- fun_inv_jsize: `%%`(v_n, var_0) + def $inv_jsizenn{v_n : nat}(v_n) = $inv_jsize(v_n) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec def $lunpack(v_lanetype : lanetype) : numtype @@ -1876,191 +1727,59 @@ relation fun_unpack: `%%`(storagetype, valtype) -- wf_valtype: `%`(I32_valtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_nunpack_before_fun_nunpack_case_6: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_5: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_4: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_nunpack: `%%`(storagetype, numtype?) +def $nunpack(v_storagetype : storagetype) : numtype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_0: - `%%`(I32_storagetype, ?(I32_numtype)) - + def $nunpack(I32_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_1: - `%%`(I64_storagetype, ?(I64_numtype)) - + def $nunpack(I64_storagetype) = ?(I64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_2: - `%%`(F32_storagetype, ?(F32_numtype)) - + def $nunpack(F32_storagetype) = ?(F32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_3: - `%%`(F64_storagetype, ?(F64_numtype)) - + def $nunpack(F64_storagetype) = ?(F64_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_4: - `%%`(I8_storagetype, ?(I32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_5: - `%%`(I16_storagetype, ?(I32_numtype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_nunpack_case_6{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_nunpack_before_fun_nunpack_case_6: `%`(x0) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_vunpack_before_fun_vunpack_case_1: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_0: - `%`(V128_storagetype) - -;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_vunpack: `%%`(storagetype, vectype?) + def $nunpack(I8_storagetype) = ?(I32_numtype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_0: - `%%`(V128_storagetype, ?(V128_vectype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_vunpack_case_1{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_vunpack_before_fun_vunpack_case_1: `%`(x0) + def $nunpack(I16_storagetype) = ?(I32_numtype) + def $nunpack{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_cunpack_before_fun_cunpack_case_13: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_12: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_11: - `%`(I8_storagetype) - +def $vunpack(v_storagetype : storagetype) : vectype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_10: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_9: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_8: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_7: - `%`(I32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_0: - `%`(I32_storagetype) + def $vunpack(V128_storagetype) = ?(V128_vectype) + def $vunpack{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_cunpack: `%%`(storagetype, consttype?) +def $cunpack(v_storagetype : storagetype) : consttype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_0: - `%%`(I32_storagetype, ?(I32_consttype)) - + def $cunpack(I32_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_1: - `%%`(I64_storagetype, ?(I64_consttype)) - + def $cunpack(I64_storagetype) = ?(I64_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_2: - `%%`(F32_storagetype, ?(F32_consttype)) - + def $cunpack(F32_storagetype) = ?(F32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_3: - `%%`(F64_storagetype, ?(F64_consttype)) - - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_4: - `%%`(V128_storagetype, ?(V128_consttype)) - + def $cunpack(F64_storagetype) = ?(F64_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_5: - `%%`(I8_storagetype, ?(I32_consttype)) - + def $cunpack(V128_storagetype) = ?(V128_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_6: - `%%`(I16_storagetype, ?(I32_consttype)) - + def $cunpack(I8_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_7: - `%%`(I32_storagetype, ?($consttype_numtype($lunpack(I32_lanetype)))) - + def $cunpack(I16_storagetype) = ?(I32_consttype) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_8: - `%%`(I64_storagetype, ?($consttype_numtype($lunpack(I64_lanetype)))) - + def $cunpack(I32_storagetype) = ?($consttype_numtype($lunpack(I32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_9: - `%%`(F32_storagetype, ?($consttype_numtype($lunpack(F32_lanetype)))) - + def $cunpack(I64_storagetype) = ?($consttype_numtype($lunpack(I64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_10: - `%%`(F64_storagetype, ?($consttype_numtype($lunpack(F64_lanetype)))) - + def $cunpack(F32_storagetype) = ?($consttype_numtype($lunpack(F32_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_11: - `%%`(I8_storagetype, ?($consttype_numtype($lunpack(I8_lanetype)))) - + def $cunpack(F64_storagetype) = ?($consttype_numtype($lunpack(F64_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_12: - `%%`(I16_storagetype, ?($consttype_numtype($lunpack(I16_lanetype)))) - + def $cunpack(I8_storagetype) = ?($consttype_numtype($lunpack(I8_lanetype))) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_cunpack_case_13{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_cunpack_before_fun_cunpack_case_13: `%`(x0) + 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(v_addrtype : addrtype, v_addrtype_0 : addrtype) : addrtype @@ -2080,85 +1799,110 @@ relation fun_diffrt: `%%%`(reftype, reftype, reftype) -- wf_reftype: `%`(REF_reftype(null_1_opt, ht_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_as_deftype_before_fun_as_deftype_case_1: `%`(typeuse) +def $as_deftype(v_typeuse : typeuse) : deftype? ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_0{v_rectype : rectype, v_n : n}: - `%`(_DEF_typeuse(v_rectype, v_n)) + def $as_deftype{v_rectype : rectype, v_n : n}(_DEF_typeuse(v_rectype, v_n)) = ?(_DEF_deftype(v_rectype, v_n)) + def $as_deftype{x0 : typeuse}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec -relation fun_as_deftype: `%%`(typeuse, deftype?) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_0{v_rectype : rectype, v_n : n}: - `%%`(_DEF_typeuse(v_rectype, v_n), ?(_DEF_deftype(v_rectype, v_n))) +rec { - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec - rule fun_as_deftype_case_1{x0 : typeuse}: - `%%`(x0, ?()) - -- ~ fun_as_deftype_before_fun_as_deftype_case_1: `%`(x0) +;; ../../../../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 -rec { + ;; ../../../../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.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 + 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: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: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: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: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: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 @@ -7559,30 +7303,28 @@ relation Blocktype_ok: `%|-%:%`(context, blocktype, instrtype) ;; ../../../../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*, var_0 : deftype?}: + rule catch{C : context, x : idx, l : labelidx, t_lst : valtype*}: `%|-%:OK`(C, CATCH_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_0), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_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([]))) -- if ($proj_uN_0(l).0 < |C.LABELS_context|) -- Resulttype_sub: `%|-%<:%`(C, `%`_resulttype(t_lst), C.LABELS_context[$proj_uN_0(l).0]) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec - rule catch_ref{C : context, x : idx, l : labelidx, t_lst : valtype*, var_0 : deftype?}: + rule catch_ref{C : context, x : idx, l : labelidx, t_lst : valtype*}: `%|-%:OK`(C, CATCH_REF_catch(x, l)) -- wf_context: `%`(C) -- wf_catch: `%`(CATCH_REF_catch(x, l)) -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_0), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_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([]))) -- 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]) - -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) ;; ../../../../specification/wasm-3.0/2.3-validation.instructions.spectec rule catch_all{C : context, l : labelidx}: @@ -7967,18 +7709,17 @@ relation Instr_ok: `%|-%:%`(context, instr, instrtype) -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_3_lst), [], `%`_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*, var_0 : deftype?}: + 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))) -- 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))) - -- if (var_0 =/= ?()) - -- Expand: `%~~%`(!(var_0), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_resulttype([]))) - -- Instrtype_ok: `%|-%:OK`(C, `%->_%%`_instrtype(`%`_resulttype(t_1_lst), [], `%`_resulttype(t_2_lst))) + -- if ($as_deftype(C.TAGS_context[$proj_uN_0(x).0]) =/= ?()) -- if ($proj_uN_0(x).0 < |C.TAGS_context|) - -- fun_as_deftype: `%%`(C.TAGS_context[$proj_uN_0(x).0], var_0) + -- 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))) ;; ../../../../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*}: @@ -9304,7 +9045,7 @@ relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../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*, var_1 : funcidx*, var_0 : moduletype}: + 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(`%`_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)), var_0) -- wf_context: `%`(C) -- wf_context: `%`(C') @@ -9340,11 +9081,16 @@ relation Module_ok: `|-%:%`(module, moduletype) -- 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 = var_1) - -- 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 (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) + -- 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: `%%`(`%%%%%%`_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst), var_1) -- fun_clos_moduletype: `%%%`(C, `%->%`_moduletype(xt_I_lst, xt_E_lst), var_0) @@ -9493,69 +9239,23 @@ relation fun_inv_signed_: `%%%`(N, 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 -relation fun_sx_before_fun_sx_case_7: `%`(storagetype) - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_6: - `%`(I16_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_5: - `%`(I8_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_4: - `%`(V128_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_3: - `%`(F64_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_2: - `%`(F32_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_1: - `%`(I64_storagetype) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_0: - `%`(I32_storagetype) - -;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec -relation fun_sx: `%%`(storagetype, sx??) +def $fun_sx(v_storagetype : storagetype) : sx?? ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_0: - `%%`(I32_storagetype, ?(?())) - + def $fun_sx(I32_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_1: - `%%`(I64_storagetype, ?(?())) - + def $fun_sx(I64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_2: - `%%`(F32_storagetype, ?(?())) - + def $fun_sx(F32_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_3: - `%%`(F64_storagetype, ?(?())) - + def $fun_sx(F64_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_4: - `%%`(V128_storagetype, ?(?())) - + def $fun_sx(V128_storagetype) = ?(?()) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_5: - `%%`(I8_storagetype, ?(?(S_sx))) - - ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_6: - `%%`(I16_storagetype, ?(?(S_sx))) - + def $fun_sx(I8_storagetype) = ?(?(S_sx)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_sx_case_7{x0 : storagetype}: - `%%`(x0, ?()) - -- ~ fun_sx_before_fun_sx_case_7: `%`(x0) + def $fun_sx(I16_storagetype) = ?(?(S_sx)) + def $fun_sx{x0 : storagetype}(x0) = ?() + -- otherwise ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec relation fun_zero: `%%`(lanetype, lane_) @@ -10109,18 +9809,16 @@ relation fun_cunpacknum_: `%%%`(storagetype, lit_, lit_) `%%%`(V128_storagetype, c, c) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec - rule fun_cunpacknum__case_5{c : uN, var_0 : consttype?}: + rule fun_cunpacknum__case_5{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)))) - -- fun_cunpack: `%%`($storagetype_packtype(I8_packtype), var_0) - -- if (var_0 =/= ?()) - -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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)))) + -- if ($cunpack($storagetype_packtype(I8_packtype)) =/= ?()) + -- 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 - rule fun_cunpacknum__case_6{c : uN, var_0 : consttype?}: + rule fun_cunpacknum__case_6{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)))) - -- fun_cunpack: `%%`($storagetype_packtype(I16_packtype), var_0) - -- if (var_0 =/= ?()) - -- wf_lit_: `%%`($storagetype_consttype(!(var_0)), 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)))) + -- if ($cunpack($storagetype_packtype(I16_packtype)) =/= ?()) + -- 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 fun_unop_: `%%%%`(numtype, unop_, num_, num_*) @@ -15508,66 +15206,101 @@ relation fun_unpackfield_: `%%%%`(storagetype, sx?, fieldval, 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 @@ -16714,7 +16447,7 @@ relation Step_pure: `%~>%`(instr*, 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_*, var_0_lst : uN*}: + rule vtestop{c_1 : vec_, v_Jnn : Jnn, v_M : M, c : num_, i_lst : lane_*, var_1_lst : uN*, var_0 : nat}: `%~>%`([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)]) -- (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)) @@ -16723,10 +16456,11 @@ relation Step_pure: `%~>%`(instr*, instr*) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M))) -- if (i_lst = $lanes_(`%X%`_shape($lanetype_Jnn(v_Jnn), `%`_dim(v_M)), c_1)) -- if ($proj_num__0(c) =/= ?()) - -- if ($proj_uN_0(!($proj_num__0(c))).0 = $prod($proj_uN_0(var_0).0*{var_0 <- var_0_lst})) - -- if (|var_0_lst| = |i_lst|) + -- if ($proj_uN_0(!($proj_num__0(c))).0 = var_0) + -- if (|var_1_lst| = |i_lst|) -- (if ($proj_lane__2(i) =/= ?()))*{i <- i_lst} - -- (fun_inez_: `%%%`($jsizenn(v_Jnn), !($proj_lane__2(i)), var_0))*{var_0 <- var_0_lst, i <- i_lst} + -- (fun_inez_: `%%%`($jsizenn(v_Jnn), !($proj_lane__2(i)), var_1))*{var_1 <- var_1_lst, i <- i_lst} + -- fun_prod: `%%`($proj_uN_0(var_1).0*{var_1 <- var_1_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_, var_0 : vec_}: @@ -17294,7 +17028,7 @@ relation Step_read_before_array_copy_le: `%`(config) ;; ../../../../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, var_0 : sx??}: + 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)])) -- 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)) @@ -17312,9 +17046,8 @@ relation Step_read_before_array_copy_gt: `%`(config) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_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))) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx_opt = !(var_0))) - -- fun_sx: `%%`(zt_2, var_0) + -- 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)))) ;; ../../../../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}: @@ -17389,16 +17122,15 @@ relation Step_read_before_array_init_elem_succ: `%`(config) ;; ../../../../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, var_0 : nat?}: + 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)])) -- 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: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -17419,16 +17151,15 @@ relation Step_read_before_array_init_data_num: `%`(config) -- if (v_n = 0) ;; ../../../../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, var_0 : nat?}: + 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)])) -- 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: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -18157,33 +17888,30 @@ relation Step_read: `%~>%`(config, instr*) -- if (ref_lst = $fun_elem(z, y).REFS_eleminst[$proj_uN_0(!($proj_num__0(i))).0 : v_n]) ;; ../../../../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, var_0 : nat?}: + 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]) -- 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: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- if ($proj_num__0(i) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i))).0 + ((((v_n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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?, var_3 : nat?, var_2_lst : lit_*, var_1 : consttype?, var_0_lst : instr*}: + rule array_new_data_num{z : state, i : num_, v_n : n, x : idx, y : idx, zt : storagetype, c_lst : lit_*, mut_opt : mut?, var_1_lst : lit_*, var_0_lst : instr*}: `%~>%`(`%;%`_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)]), var_0_lst ++ [`ARRAY.NEW_FIXED`_instr(x, `%`_u32(v_n))]) -- (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))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) - -- if (var_3 =/= ?()) + -- if ($zsize(zt) =/= ?()) -- if ($proj_num__0(i) =/= ?()) - -- if ($concatn_(syntax byte, $zbytes_(zt, c)^v_n{c <- c_lst}, (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) = $fun_data(z, y).BYTES_datainst[$proj_uN_0(!($proj_num__0(i))).0 : ((((v_n * !(var_3)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- fun_zsize: `%%`(zt, var_3) - -- (fun_cunpacknum_: `%%%`(zt, c, var_2))^v_n{var_2 <- var_2_lst, c <- c_lst} - -- fun_cunpack: `%%`(zt, var_1) - -- (if (var_1 =/= ?()))^v_n{} - -- (fun_const: `%%%`(!(var_1), var_2, var_0))^v_n{var_2 <- var_2_lst, var_0 <- var_0_lst} + -- 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)]) + -- (fun_cunpacknum_: `%%%`(zt, c, var_1))^v_n{var_1 <- var_1_lst, c <- c_lst} + -- (if ($cunpack(zt) =/= ?()))^v_n{} + -- (fun_const: `%%%`(!($cunpack(zt)), var_1, var_0))^v_n{var_1 <- var_1_lst, var_0 <- var_0_lst} ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rule array_get_null{z : state, i : num_, sx_opt : sx?, x : idx}: @@ -18298,7 +18026,7 @@ relation Step_read: `%~>%`(config, instr*) -- if (v_n = 0) ;; ../../../../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, var_0 : sx??}: + 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)]) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -18316,12 +18044,11 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_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))) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(i_1))).0 <= $proj_uN_0(!($proj_num__0(i_2))).0) /\ (sx_opt = !(var_0))) - -- fun_sx: `%%`(zt_2, var_0) + -- 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)))) ;; ../../../../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, var_0 : sx??}: + 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)]) -- if ($proj_num__0(i_1) =/= ?()) -- if ($proj_num__0(i_2) =/= ?()) @@ -18339,9 +18066,8 @@ relation Step_read: `%~>%`(config, instr*) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt_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 (var_0 =/= ?()) - -- if (sx_opt = !(var_0)) - -- fun_sx: `%%`(zt_2, var_0) + -- if ($fun_sx(zt_2) =/= ?()) + -- if (sx_opt = !($fun_sx(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}: @@ -18407,16 +18133,15 @@ relation Step_read: `%~>%`(config, instr*) -- if (($proj_uN_0(!($proj_num__0(i))).0 + v_n) > |$fun_arrayinst(z)[a].FIELDS_arrayinst|) ;; ../../../../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, var_0 : nat?}: + 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]) -- 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: `%`(TRAP_instr) -- wf_comptype: `%`(ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- Expand: `%~~%`($fun_type(z, x), ARRAY_comptype(`%%`_fieldtype(mut_opt, zt))) -- if ($proj_num__0(j) =/= ?()) - -- if (var_0 =/= ?()) - -- if (($proj_uN_0(!($proj_num__0(j))).0 + ((((v_n * !(var_0)) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)) > |$fun_data(z, y).BYTES_datainst|) - -- fun_zsize: `%%`(zt, var_0) + -- 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|) ;; ../../../../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}: @@ -18426,29 +18151,27 @@ relation Step_read: `%~>%`(config, instr*) -- if (v_n = 0) ;; ../../../../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?, var_3 : nat?, var_2 : lit_, var_1 : consttype?, var_0 : 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(v_n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 + (((!(var_3) : 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)]) + 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?, var_1 : lit_, var_0 : 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(v_n))) `ARRAY.INIT_DATA`_instr(x, y)]), [`REF.ARRAY_ADDR`_instr(a) CONST_instr(I32_numtype, i) var_0 `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 ($proj_num__0(i) =/= ?()) -- if ($proj_num__0(j) =/= ?()) - -- if (var_3 =/= ?()) + -- if ($zsize(zt) =/= ?()) -- 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_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 + (((!(var_3) : 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(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))) -- ~ 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 : (((!(var_3) : nat <:> rat) / (8 : nat <:> rat)) : rat <:> nat)]) - -- fun_zsize: `%%`(zt, var_3) - -- fun_cunpacknum_: `%%%`(zt, c, var_2) - -- fun_cunpack: `%%`(zt, var_1) - -- if (var_1 =/= ?()) - -- fun_const: `%%%`(!(var_1), var_2, var_0) + -- 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)]) + -- fun_cunpacknum_: `%%%`(zt, c, var_1) + -- if ($cunpack(zt) =/= ?()) + -- fun_const: `%%%`(!($cunpack(zt)), var_1, var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec rec { @@ -18507,18 +18230,17 @@ relation Step: `%~>%`(config, config) -- Step: `%~>%`(`%;%`_config(`%;%`_state(s, f'), instr_lst), `%;%`_config(`%;%`_state(s', f''), instr'_lst)) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:231.1-235.49 - rule throw{z : state, v_n : n, val_lst : val*, x : idx, exn : exninst, a : addr, t_lst : valtype*, var_1 : deftype?, var_0 : state}: + rule throw{z : state, v_n : n, val_lst : val*, x : idx, exn : exninst, a : addr, t_lst : valtype*, var_0 : state}: `%~>%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [THROW_instr(x)]), `%;%`_config(var_0, [`REF.EXN_ADDR`_instr(a) THROW_REF_instr])) -- wf_config: `%`(`%;%`_config(z, $instr_val(v_val)^v_n{v_val <- val_lst} ++ [THROW_instr(x)])) -- wf_config: `%`(`%;%`_config(var_0, [`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_exninst: `%`({TAG $fun_tagaddr(z)[$proj_uN_0(x).0], FIELDS val_lst}) - -- if (var_1 =/= ?()) - -- Expand: `%~~%`(!(var_1), `FUNC%->%`_comptype(`%`_resulttype(t_lst), `%`_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 (exn = {TAG $fun_tagaddr(z)[$proj_uN_0(x).0], FIELDS val_lst}) - -- fun_as_deftype: `%%`($fun_tag(z, x).TYPE_taginst, var_1) -- fun_add_exninst: `%%%`(z, [exn], var_0) ;; ../../../../specification/wasm-3.0/4.3-execution.instructions.spectec:309.1-310.56 @@ -19044,28 +18766,33 @@ relation fun_allocexports: `%%%`(moduleinst, export*, exportinst*) ;; ../../../../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 - 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, 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*, 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**, aa_I_lst : tagaddr*, ga_I_lst : globaladdr*, ma_I_lst : memaddr*, ta_I_lst : tableaddr*, fa_I_lst : funcaddr*, dt_lst : deftype*, fa_lst : nat*, s_1 : store, aa_lst : tagaddr*, s_2 : store, ga_lst : globaladdr*, s_3 : store, ma_lst : memaddr*, s_4 : store, ta_lst : tableaddr*, s_5 : store, da_lst : dataaddr*, s_6 : store, ea_lst : elemaddr*, xi_lst : exportinst*, var_13 : exportinst*, var_12 : (store, funcaddr*), var_11_lst : elemtype*, var_10 : (store, elemaddr*), var_9 : (store, dataaddr*), var_8_lst : tabletype*, var_7 : (store, tableaddr*), var_6_lst : memtype*, var_5 : (store, memaddr*), var_4_lst : globaltype*, var_3 : (store, globaladdr*), var_2_lst : tagtype*, var_1 : (store, tagaddr*), var_0 : deftype*}: + 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, 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*, 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**, aa_I_lst : tagaddr*, ga_I_lst : globaladdr*, ma_I_lst : memaddr*, ta_I_lst : tableaddr*, fa_I_lst : funcaddr*, dt_lst : deftype*, fa_lst : nat*, s_1 : store, aa_lst : tagaddr*, s_2 : store, ga_lst : globaladdr*, s_3 : store, ma_lst : memaddr*, s_4 : store, ta_lst : tableaddr*, s_5 : store, da_lst : dataaddr*, s_6 : store, ea_lst : elemaddr*, xi_lst : exportinst*, var_18 : 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)) - -- fun_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, var_13) + -- fun_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, var_18) -- (if ($proj_uN_0(x#4).0 < |dt_lst|))*{x#4 <- x_lst} - -- fun_allocfuncs: `%%%%%`(s_6, dt_lst[$proj_uN_0(x#4).0]*{x#4 <- x_lst}, FUNC_funccode(x#5, local_lst#86, expr_F#3)*{expr_F#3 <- expr_F_lst, local_lst#86 <- local_lst_lst, x#5 <- x_lst}, v_moduleinst^|func_lst|{}, var_12) - -- if (|var_11_lst| = |elemtype_lst|) - -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- dt_lst}, var_11))*{var_11 <- var_11_lst, elemtype#3 <- elemtype_lst} - -- fun_allocelems: `%%%%`(s_5, var_11_lst, ref_E_lst_lst, var_10) - -- fun_allocdatas: `%%%%`(s_4, OK_datatype^|data_lst|{}, byte_lst_lst, var_9) - -- if (|var_8_lst| = |tabletype_lst|) - -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- dt_lst}, var_8))*{var_8 <- var_8_lst, tabletype#160 <- tabletype_lst} - -- fun_alloctables: `%%%%`(s_3, var_8_lst, ref_T_lst, var_7) - -- if (|var_6_lst| = |memtype_lst|) - -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- dt_lst}, var_6))*{var_6 <- var_6_lst, memtype#126 <- memtype_lst} - -- fun_allocmems: `%%%`(s_2, var_6_lst, var_5) - -- if (|var_4_lst| = |globaltype_lst|) - -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- dt_lst}, var_4))*{var_4 <- var_4_lst, globaltype#126 <- globaltype_lst} - -- fun_allocglobals: `%%%%`(s_1, var_4_lst, val_G_lst, var_3) - -- if (|var_2_lst| = |tagtype_lst|) - -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- dt_lst}, var_2))*{var_2 <- var_2_lst, tagtype#82 <- tagtype_lst} - -- fun_alloctags: `%%%`(s, var_2_lst, var_1) - -- fun_alloctypes: `%%`(type_lst, var_0) + -- fun_allocfuncs: `%%%%%`(s_6, dt_lst[$proj_uN_0(x#4).0]*{x#4 <- x_lst}, FUNC_funccode(x#5, local_lst#86, expr_F#3)*{expr_F#3 <- expr_F_lst, local_lst#86 <- local_lst_lst, x#5 <- x_lst}, v_moduleinst^|func_lst|{}, var_17) + -- if (|var_16_lst| = |elemtype_lst|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- dt_lst}, var_16))*{var_16 <- var_16_lst, elemtype#3 <- 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) + -- if (|var_13_lst| = |tabletype_lst|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- dt_lst}, var_13))*{var_13 <- var_13_lst, tabletype#160 <- tabletype_lst} + -- fun_alloctables: `%%%%`(s_3, var_13_lst, ref_T_lst, var_12) + -- if (|var_11_lst| = |memtype_lst|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- dt_lst}, var_11))*{var_11 <- var_11_lst, memtype#126 <- memtype_lst} + -- fun_allocmems: `%%%`(s_2, var_11_lst, var_10) + -- if (|var_9_lst| = |globaltype_lst|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- dt_lst}, var_9))*{var_9 <- var_9_lst, globaltype#126 <- globaltype_lst} + -- fun_allocglobals: `%%%%`(s_1, var_9_lst, val_G_lst, var_8) + -- if (|var_7_lst| = |tagtype_lst|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- dt_lst}, var_7))*{var_7 <- var_7_lst, tagtype#82 <- 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) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(v_moduleinst) -- wf_store: `%`(s_1) @@ -19099,21 +18826,21 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* -- if (func_lst = FUNC_func(x#3, local_lst#84, expr_F#2)*{expr_F#2 <- expr_F_lst, local_lst#84 <- local_lst_lst, x#3 <- x_lst}) -- if (data_lst = DATA_data(byte_lst#112, datamode#112)*{byte_lst#112 <- byte_lst_lst, datamode#112 <- datamode_lst}) -- if (elem_lst = ELEM_elem(elemtype#2, expr_E_lst#2, elemmode#232)*{elemmode#232 <- elemmode_lst, elemtype#2 <- elemtype_lst, expr_E_lst#2 <- expr_E_lst_lst}) - -- if (aa_I_lst = $tagsxa(externaddr_lst)) - -- if (ga_I_lst = $globalsxa(externaddr_lst)) - -- if (ma_I_lst = $memsxa(externaddr_lst)) - -- if (ta_I_lst = $tablesxa(externaddr_lst)) - -- if (fa_I_lst = $funcsxa(externaddr_lst)) - -- if (dt_lst = var_0) + -- if (aa_I_lst = var_0) + -- if (ga_I_lst = var_1) + -- if (ma_I_lst = var_2) + -- if (ta_I_lst = var_3) + -- if (fa_I_lst = var_4) + -- if (dt_lst = var_5) -- if (fa_lst = (|s.FUNCS_store| + i_F#1)^(i_F#1<|func_lst|){}) - -- if ((s_1, aa_lst) = var_1) - -- if ((s_2, ga_lst) = var_3) - -- if ((s_3, ma_lst) = var_5) - -- if ((s_4, ta_lst) = var_7) - -- if ((s_5, da_lst) = var_9) - -- if ((s_6, ea_lst) = var_10) - -- if ((s_7, fa_lst) = var_12) - -- if (xi_lst = var_13) + -- if ((s_1, aa_lst) = var_6) + -- if ((s_2, ga_lst) = var_8) + -- if ((s_3, ma_lst) = var_10) + -- if ((s_4, ta_lst) = var_12) + -- if ((s_5, da_lst) = var_14) + -- if ((s_6, ea_lst) = var_15) + -- if ((s_7, fa_lst) = var_17) + -- if (xi_lst = var_18) -- 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}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -19221,17 +18948,21 @@ relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec - rule fun_instantiate_case_0{s : store, v_module : module, externaddr_lst : externaddr*, s'''' : store, v_moduleinst : moduleinst, instr_E_lst : instr*, instr_D_lst : instr*, instr_S_opt : instr?, xt_I_lst : externtype*, xt_E_lst : externtype*, 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*, 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, z' : state, val_G_lst : val*, z'' : state, ref_T_lst : ref*, z''' : state, ref_E_lst_lst : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, var_7_lst : instr**, var_6_lst : instr**, var_5 : (store, moduleinst), var_4 : (state, ref**), var_3 : (state, ref*), var_2 : (state, val*), var_1 : deftype*, var_0 : deftype*}: + rule fun_instantiate_case_0{s : store, v_module : module, externaddr_lst : externaddr*, s'''' : store, v_moduleinst : moduleinst, instr_E_lst : instr*, instr_D_lst : instr*, instr_S_opt : instr?, xt_I_lst : externtype*, xt_E_lst : externtype*, 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*, 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, z' : state, val_G_lst : val*, z'' : state, ref_T_lst : ref*, z''' : state, ref_E_lst_lst : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, var_11_lst : instr**, var_10_lst : instr**, var_9 : (store, moduleinst), var_8 : (state, ref**), var_7 : (state, ref*), var_6 : (state, val*), var_5 : funcaddr*, var_4 : globaladdr*, var_3 : deftype*, var_2 : funcaddr*, var_1 : globaladdr*, var_0 : deftype*}: `%%%%`(s, v_module, externaddr_lst, `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE v_moduleinst}), instr_E_lst ++ instr_D_lst ++ lift(instr_S_opt))) -- (if (i_E#2 < |elem_lst|))^(i_E#2<|elem_lst|){} - -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem_lst[i_E#2], var_7))^(i_E#2<|elem_lst|){var_7 <- var_7_lst} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem_lst[i_E#2], var_11))^(i_E#2<|elem_lst|){var_11 <- var_11_lst} -- (if (i_D#2 < |data_lst|))^(i_D#2<|data_lst|){} - -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data_lst[i_D#2], var_6))^(i_D#2<|data_lst|){var_6 <- var_6_lst} - -- fun_allocmodule: `%%%%%%%`(s''', v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst, var_5) - -- fun_evalexprss: `%%%`(z'', expr_E_lst_lst, var_4) - -- fun_evalexprs: `%%%`(z', expr_T_lst, var_3) - -- fun_evalglobals: `%%%%`(z, globaltype_lst, expr_G_lst, var_2) - -- fun_alloctypes: `%%`(type_lst, var_1) + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data_lst[i_D#2], var_10))^(i_D#2<|data_lst|){var_10 <- var_10_lst} + -- fun_allocmodule: `%%%%%%%`(s''', v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst, var_9) + -- fun_evalexprss: `%%%`(z'', expr_E_lst_lst, var_8) + -- fun_evalexprs: `%%%`(z', expr_T_lst, var_7) + -- fun_evalglobals: `%%%%`(z, globaltype_lst, expr_G_lst, var_6) + -- fun_funcsxa: `%%`(externaddr_lst, var_5) + -- fun_globalsxa: `%%`(externaddr_lst, var_4) + -- fun_alloctypes: `%%`(type_lst, var_3) + -- fun_funcsxa: `%%`(externaddr_lst, var_2) + -- fun_globalsxa: `%%`(externaddr_lst, var_1) -- fun_alloctypes: `%%`(type_lst, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') @@ -19253,7 +18984,7 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (|elemmode_lst| = |reftype_lst|) -- (wf_elem: `%`(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} -- (wf_start: `%`(START_start(x#6)))?{x#6 <- x_opt} - -- wf_moduleinst: `%`({TYPES var_0, 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 []}) + -- wf_moduleinst: `%`({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 []}) -- wf_state: `%`(`%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) -- wf_state: `%`(`%;%`_state(s''', f)) -- (wf_uN: `%%`(32, `%`_uN(i_D#1)))^(i_D#1<|data_lst|){} @@ -19268,15 +18999,15 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (data_lst = DATA_data(byte_lst#119, datamode#118)*{byte_lst#119 <- byte_lst_lst, datamode#118 <- datamode_lst}) -- if (elem_lst = ELEM_elem(reftype#519, expr_E_lst#4, elemmode#239)*{elemmode#239 <- elemmode_lst, expr_E_lst#4 <- expr_E_lst_lst, reftype#519 <- reftype_lst}) -- if (start_opt = START_start(x#8)?{x#8 <- x_opt}) - -- if (moduleinst_0 = {TYPES var_1, 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 []}) + -- if (moduleinst_0 = {TYPES var_3, TAGS [], GLOBALS var_4, MEMS [], TABLES [], FUNCS var_5 ++ (|s.FUNCS_store| + i_F#3)^(i_F#3<|func_lst|){}, DATAS [], ELEMS [], EXPORTS []}) -- if (z = `%;%`_state(s, {LOCALS [], MODULE moduleinst_0})) - -- if ((z', val_G_lst) = var_2) - -- if ((z'', ref_T_lst) = var_3) - -- if ((z''', ref_E_lst_lst) = var_4) + -- if ((z', val_G_lst) = var_6) + -- if ((z'', ref_T_lst) = var_7) + -- if ((z''', ref_E_lst_lst) = var_8) -- if (z''' = `%;%`_state(s''', f)) - -- if ((s'''', v_moduleinst) = var_5) - -- if (instr_D_lst = $concat_(syntax instr, var_6_lst)) - -- if (instr_E_lst = $concat_(syntax instr, var_7_lst)) + -- if ((s'''', v_moduleinst) = var_9) + -- if (instr_D_lst = $concat_(syntax instr, var_10_lst)) + -- if (instr_E_lst = $concat_(syntax instr, var_11_lst)) -- if (instr_S_opt = CALL_instr(x#9)?{x#9 <- x_opt}) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -19501,156 +19232,240 @@ 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.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: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: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 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: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: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: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: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: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: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: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: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: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: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: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: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: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: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 relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule fun_ordered_case_0{decl_lst : decl*}: + rule fun_ordered_case_0{decl_lst : decl*, var_0 : import*}: `%%`(decl_lst, true) - -- if ($importsd(decl_lst) = []) + -- fun_importsd: `%%`(decl_lst, var_0) + -- if (var_0 = []) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec - rule fun_ordered_case_1{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) @@ -22446,12 +22261,10 @@ grammar TfNmag(v_N : N) : fNmag ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec prod "inf" => INF_fNmag ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{var_0 : m} "nan" => NAN_fNmag(var_0) - -- fun_canon_: `%%`(v_N, var_0) + prod "nan" => NAN_fNmag($canon_(v_N)) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec - prod{v_n : n, var_0 : nat?} {{"nan:0x"} {v_n:Thexnum}} => NAN_fNmag(v_n) - -- if ((1 <= v_n) /\ (v_n < (2 ^ !(var_0)))) - -- fun_signif: `%%`(v_N, var_0) + prod{v_n : n} {{"nan:0x"} {v_n:Thexnum}} => NAN_fNmag(v_n) + -- if ((1 <= v_n) /\ (v_n < (2 ^ !($signif(v_N))))) ;; ../../../../specification/wasm-3.0/6.1-text.values.spectec grammar TfN(v_N : N) : fN @@ -24071,22 +23884,33 @@ 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, var_1 : bool, var_0 : idctxt} {{"("} {"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)) + 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(`%`_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' = 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 var_1 - -- fun_ordered: `%%`(decl_lst, var_1) + -- 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 diff --git a/spectec/test-middlend/test.spectec.exp b/spectec/test-middlend/test.spectec.exp index e34d0ac44e..485f2a528f 100644 --- a/spectec/test-middlend/test.spectec.exp +++ b/spectec/test-middlend/test.spectec.exp @@ -310,48 +310,25 @@ relation TestNestedIter: `%|-%`(nat***, nat**) -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec -relation fun_t_totalize_before_fun_t_totalize_case_2: `%`(nat) - ;; test.spectec - rule fun_t_totalize_case_1: - `%`(10) - - ;; test.spectec - rule fun_t_totalize_case_0: - `%`(3) - -;; test.spectec -relation fun_t_totalize: `%%`(nat, nat?) - ;; test.spectec - rule fun_t_totalize_case_0: - `%%`(3, ?(5)) - +def $t_totalize(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize_case_1: - `%%`(10, ?(20)) - + def $t_totalize(3) = ?(5) ;; test.spectec - rule fun_t_totalize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_t_totalize_before_fun_t_totalize_case_2: `%`(x0) + def $t_totalize(10) = ?(20) + def $t_totalize{x0 : nat}(x0) = ?() + -- otherwise ;; test.spectec -relation fun_t_totalize2: `%%`(nat, nat?) +def $t_totalize2(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize2_case_0: - `%%`(1, ?(2)) - + def $t_totalize2(1) = ?(2) ;; test.spectec - rule fun_t_totalize2_case_1{n : nat, var_0 : nat?}: - `%%`(n, var_0) - -- fun_t_totalize: `%%`(n, var_0) + def $t_totalize2{n : nat}(n) = $t_totalize(n) ;; test.spectec -relation fun_t_totalize3: `%%`(nat, nat?) +def $t_totalize3(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize3_case_0{n : nat, var_1 : nat?, var_0 : nat?}: - `%%`(n, (iter_val#2 + iter_val#1)?{iter_val#2 <- var_0, iter_val#1 <- var_1}) - -- fun_t_totalize2: `%%`((n + 10), var_1) - -- fun_t_totalize: `%%`(n, var_0) + 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 definition-to-relation... == Running pass sideconditions... @@ -369,48 +346,25 @@ relation TestNestedIter: `%|-%`(nat***, nat**) -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec -relation fun_t_totalize_before_fun_t_totalize_case_2: `%`(nat) - ;; test.spectec - rule fun_t_totalize_case_1: - `%`(10) - - ;; test.spectec - rule fun_t_totalize_case_0: - `%`(3) - -;; test.spectec -relation fun_t_totalize: `%%`(nat, nat?) - ;; test.spectec - rule fun_t_totalize_case_0: - `%%`(3, ?(5)) - +def $t_totalize(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize_case_1: - `%%`(10, ?(20)) - + def $t_totalize(3) = ?(5) ;; test.spectec - rule fun_t_totalize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_t_totalize_before_fun_t_totalize_case_2: `%`(x0) + def $t_totalize(10) = ?(20) + def $t_totalize{x0 : nat}(x0) = ?() + -- otherwise ;; test.spectec -relation fun_t_totalize2: `%%`(nat, nat?) +def $t_totalize2(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize2_case_0: - `%%`(1, ?(2)) - + def $t_totalize2(1) = ?(2) ;; test.spectec - rule fun_t_totalize2_case_1{n : nat, var_0 : nat?}: - `%%`(n, var_0) - -- fun_t_totalize: `%%`(n, var_0) + def $t_totalize2{n : nat}(n) = $t_totalize(n) ;; test.spectec -relation fun_t_totalize3: `%%`(nat, nat?) +def $t_totalize3(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize3_case_0{n : nat, var_1 : nat?, var_0 : nat?}: - `%%`(n, (iter_val#2 + iter_val#1)?{iter_val#2 <- var_0, iter_val#1 <- var_1}) - -- fun_t_totalize2: `%%`((n + 10), var_1) - -- fun_t_totalize: `%%`(n, var_0) + 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 alias-demut... @@ -428,48 +382,25 @@ relation TestNestedIter: `%|-%`(nat***, nat**) -- (if (|n*{n <- `n*`}| = m))*{m <- `m*`, `n*` <- `n**`}+{`m*` <- `m**`, `n**` <- `n***`} ;; test.spectec -relation fun_t_totalize_before_fun_t_totalize_case_2: `%`(nat) - ;; test.spectec - rule fun_t_totalize_case_1: - `%`(10) - - ;; test.spectec - rule fun_t_totalize_case_0: - `%`(3) - -;; test.spectec -relation fun_t_totalize: `%%`(nat, nat?) - ;; test.spectec - rule fun_t_totalize_case_0: - `%%`(3, ?(5)) - +def $t_totalize(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize_case_1: - `%%`(10, ?(20)) - + def $t_totalize(3) = ?(5) ;; test.spectec - rule fun_t_totalize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_t_totalize_before_fun_t_totalize_case_2: `%`(x0) + def $t_totalize(10) = ?(20) + def $t_totalize{x0 : nat}(x0) = ?() + -- otherwise ;; test.spectec -relation fun_t_totalize2: `%%`(nat, nat?) +def $t_totalize2(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize2_case_0: - `%%`(1, ?(2)) - + def $t_totalize2(1) = ?(2) ;; test.spectec - rule fun_t_totalize2_case_1{n : nat, var_0 : nat?}: - `%%`(n, var_0) - -- fun_t_totalize: `%%`(n, var_0) + def $t_totalize2{n : nat}(n) = $t_totalize(n) ;; test.spectec -relation fun_t_totalize3: `%%`(nat, nat?) +def $t_totalize3(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize3_case_0{n : nat, var_1 : nat?, var_0 : nat?}: - `%%`(n, (iter_val#2 + iter_val#1)?{iter_val#2 <- var_0, iter_val#1 <- var_1}) - -- fun_t_totalize2: `%%`((n + 10), var_1) - -- fun_t_totalize: `%%`(n, var_0) + 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 alias-demut... == Running pass improve-ids... @@ -487,48 +418,25 @@ relation TestNestedIter: `%|-%`(nat***, nat**) -- (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 -relation fun_t_totalize_before_fun_t_totalize_case_2: `%`(nat) - ;; test.spectec - rule fun_t_totalize_case_1: - `%`(10) - - ;; test.spectec - rule fun_t_totalize_case_0: - `%`(3) - -;; test.spectec -relation fun_t_totalize: `%%`(nat, nat?) - ;; test.spectec - rule fun_t_totalize_case_0: - `%%`(3, ?(5)) - +def $t_totalize(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize_case_1: - `%%`(10, ?(20)) - + def $t_totalize(3) = ?(5) ;; test.spectec - rule fun_t_totalize_case_2{x0 : nat}: - `%%`(x0, ?()) - -- ~ fun_t_totalize_before_fun_t_totalize_case_2: `%`(x0) + def $t_totalize(10) = ?(20) + def $t_totalize{x0 : nat}(x0) = ?() + -- otherwise ;; test.spectec -relation fun_t_totalize2: `%%`(nat, nat?) +def $t_totalize2(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize2_case_0: - `%%`(1, ?(2)) - + def $t_totalize2(1) = ?(2) ;; test.spectec - rule fun_t_totalize2_case_1{n : nat, var_0 : nat?}: - `%%`(n, var_0) - -- fun_t_totalize: `%%`(n, var_0) + def $t_totalize2{n : nat}(n) = $t_totalize(n) ;; test.spectec -relation fun_t_totalize3: `%%`(nat, nat?) +def $t_totalize3(nat : nat) : nat? ;; test.spectec - rule fun_t_totalize3_case_0{n : nat, var_1 : nat?, var_0 : nat?}: - `%%`(n, (iter_val#2 + iter_val#1)?{iter_val#2 <- var_0, iter_val#1 <- var_1}) - -- fun_t_totalize2: `%%`((n + 10), var_1) - -- fun_t_totalize: `%%`(n, var_0) + 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 improve-ids... == Complete. From f93d7a47fc4ede8463594b9c2fe835546a1e2f37 Mon Sep 17 00:00:00 2001 From: DCupello1 Date: Mon, 18 May 2026 16:05:05 +0100 Subject: [PATCH 11/11] Fix tests and ordering of premises (in anticipation of let) --- spectec/src/middlend/deftorel.ml | 2 +- .../09-definition-to-relation.il | 367 ++++++++-------- .../specification.exp/10-sideconditions.il | 391 +++++++++--------- .../specification.exp/11-alias-demut.il | 391 +++++++++--------- .../specification.exp/12-improve-ids.il | 391 +++++++++--------- 5 files changed, 765 insertions(+), 777 deletions(-) diff --git a/spectec/src/middlend/deftorel.ml b/spectec/src/middlend/deftorel.ml index 26830a332c..77f9662b64 100644 --- a/spectec/src/middlend/deftorel.ml +++ b/spectec/src/middlend/deftorel.ml @@ -589,7 +589,7 @@ let cvt_def_to_rel env id params r_typ clauses = 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 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_mixop, tupe, List.map (transform_prem_normal call_map env) (new_prems @ prems)) $ id.at + RuleD (fun_prefix ^ id.it ^ "_case_" ^ Int.to_string i $ id.at, quants @ new_quants, new_mixop, tupe, List.map (transform_prem_normal call_map env) (prems @ new_prems)) $ id.at ) clauses in let new_id = { id with it = fun_prefix ^ id.it } in diff --git a/spectec/test-middlend/specification.exp/09-definition-to-relation.il b/spectec/test-middlend/specification.exp/09-definition-to-relation.il index 0f3652560e..7553794a2c 100644 --- a/spectec/test-middlend/specification.exp/09-definition-to-relation.il +++ b/spectec/test-middlend/specification.exp/09-definition-to-relation.il @@ -419,35 +419,35 @@ relation fun_utf8: `%%`(char*, byte*) ;; ../../../../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]) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(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]) - -- fun_cont: `%%`(b_3, var_1) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(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]) - -- fun_cont: `%%`(b_4, var_2) - -- fun_cont: `%%`(b_3, var_1) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(b_3) -- wf_byte: `%`(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 @@ -1936,27 +1936,26 @@ relation fun_subst_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.6-401.17 relation fun_minus_recs_before_fun_minus_recs_case_3: `%%`(typevar*, typeuse*) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%`([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) - -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} -- wf_typevar: `%`(_IDX_typevar(x)) -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_0: `%%`([], []) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 @@ -1971,11 +1970,11 @@ relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, 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'*`}))) - -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} -- wf_typevar: `%`(_IDX_typevar(x)) -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 rule fun_minus_recs_case_3{x0 : typevar*, x1 : typeuse*}: @@ -2044,9 +2043,9 @@ 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_1 : heaptype, 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)) + -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) -- fun_subst_heaptype: `%%%%`(ht, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, var_1) -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 relation fun_subst_valtype: `%%%%`(valtype, typevar*, typeuse*, valtype) @@ -2130,56 +2129,56 @@ 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_1 : storagetype, var_0 : storagetype}: `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) -- fun_subst_storagetype: `%%%%`(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, var_1) -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) ;; ../../../../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_1*` : fieldtype*, `var_0*` : fieldtype*}: `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) -- (fun_subst_fieldtype: `%%%%`(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, var_1))*{var_1 <- `var_1*`, ft#2 <- `ft*`} -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) ;; ../../../../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_1 : fieldtype, var_0 : fieldtype}: `%%%%`(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, ARRAY_comptype(var_0)) + -- wf_comptype: `%`(ARRAY_comptype(var_1)) -- fun_subst_fieldtype: `%%%%`(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}, var_1) -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_comptype: `%`(ARRAY_comptype(var_1)) ;; ../../../../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_3*` : valtype*, `var_2*` : valtype*, `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#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) -- (fun_subst_valtype: `%%%%`(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_3))*{var_3 <- `var_3*`, t_2#2 <- `t_2*`} -- (fun_subst_valtype: `%%%%`(t_1#2, tv#60*{tv#60 <- `tv*`}, tu#60*{tu#60 <- `tu*`}, var_2))*{var_2 <- `var_2*`, t_1#2 <- `t_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*`} - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) ;; ../../../../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_3 : comptype, `var_2*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#4*{tu'#4 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) -- fun_subst_comptype: `%%%%`(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, var_3) -- (fun_subst_typeuse: `%%%%`(tu'#5, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}, var_2))*{var_2 <- `var_2*`, tu'#5 <- `tu'*`} -- 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'*`} - -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) ;; ../../../../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*, `tv'*` : typevar*, `tu'*` : typeuse*, var_1 : (typevar*, typeuse*)?, `var_0*` : subtype*}: `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) - -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) - -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} -- (wf_typevar: `%`(tv'#4))*{tv'#4 <- `tv'*`} -- (wf_typeuse: `%`(tu'#6))*{tu'#6 <- `tu'*`} -- if ((tv'#5*{tv'#5 <- `tv'*`}, tu'#7*{tu'#7 <- `tu'*`}) = !(var_1)) + -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) + -- (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) @@ -2206,9 +2205,9 @@ relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : valtype, var_0 : valtype}: `%%%%`(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) -- fun_subst_valtype: `%%%%`(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}, var_1) -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation fun_subst_memtype: `%%%%`(memtype, typevar*, typeuse*, memtype) @@ -2222,129 +2221,129 @@ 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_1 : reftype, var_0 : reftype}: `%%%%`(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) -- fun_subst_reftype: `%%%%`(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}, var_1) -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) ;; ../../../../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_1 : tagtype, var_0 : tagtype}: `%%%%`(TAG_externtype(jt), tv#75*{tv#75 <- `tv*`}, tu#75*{tu#75 <- `tu*`}, TAG_externtype(var_0)) + -- wf_externtype: `%`(TAG_externtype(var_1)) -- fun_subst_tagtype: `%%%%`(jt, tv#76*{tv#76 <- `tv*`}, tu#76*{tu#76 <- `tu*`}, var_1) -- fun_subst_tagtype: `%%%%`(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(TAG_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_1{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : globaltype, var_0 : globaltype}: `%%%%`(GLOBAL_externtype(gt), tv#77*{tv#77 <- `tv*`}, tu#77*{tu#77 <- `tu*`}, GLOBAL_externtype(var_0)) + -- wf_externtype: `%`(GLOBAL_externtype(var_1)) -- fun_subst_globaltype: `%%%%`(gt, tv#78*{tv#78 <- `tv*`}, tu#78*{tu#78 <- `tu*`}, var_1) -- fun_subst_globaltype: `%%%%`(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(GLOBAL_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_2{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : tabletype, var_0 : tabletype}: `%%%%`(TABLE_externtype(tt), tv#79*{tv#79 <- `tv*`}, tu#79*{tu#79 <- `tu*`}, TABLE_externtype(var_0)) + -- wf_externtype: `%`(TABLE_externtype(var_1)) -- fun_subst_tabletype: `%%%%`(tt, tv#80*{tv#80 <- `tv*`}, tu#80*{tu#80 <- `tu*`}, var_1) -- fun_subst_tabletype: `%%%%`(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(TABLE_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_3{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : memtype, var_0 : memtype}: `%%%%`(MEM_externtype(mt), tv#81*{tv#81 <- `tv*`}, tu#81*{tu#81 <- `tu*`}, MEM_externtype(var_0)) + -- wf_externtype: `%`(MEM_externtype(var_1)) -- fun_subst_memtype: `%%%%`(mt, tv#82*{tv#82 <- `tv*`}, tu#82*{tu#82 <- `tu*`}, var_1) -- fun_subst_memtype: `%%%%`(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(MEM_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_4{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_1 : typeuse, var_0 : typeuse}: `%%%%`(FUNC_externtype(tu'), tv#83*{tv#83 <- `tv*`}, tu#83*{tu#83 <- `tu*`}, FUNC_externtype(var_0)) + -- wf_externtype: `%`(FUNC_externtype(var_1)) -- fun_subst_typeuse: `%%%%`(tu', tv#84*{tv#84 <- `tv*`}, tu#84*{tu#84 <- `tu*`}, var_1) -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(FUNC_externtype(var_1)) ;; ../../../../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_3*` : externtype*, `var_2*` : externtype*, `var_1*` : externtype*, `var_0*` : externtype*}: `%%%%`(`%->%`_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(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) -- (fun_subst_externtype: `%%%%`(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`}, var_3))*{var_3 <- `var_3*`, xt_2#2 <- `xt_2*`} -- (fun_subst_externtype: `%%%%`(xt_1#2, tv#86*{tv#86 <- `tv*`}, tu#86*{tu#86 <- `tu*`}, var_2))*{var_2 <- `var_2*`, xt_1#2 <- `xt_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*`} - -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) ;; ../../../../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#88^n{tu#88 <- `tu*`}, var_0) - -- fun_subst_valtype: `%%%%`(t, _IDX_typevar(`%`_typeidx(i))^(i int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) - -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -5804,11 +5803,11 @@ 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*, free : free, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- wf_free: `%`(free) + -- if (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) - -- wf_free: `%`(free) - -- if (free = var_1) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -6271,9 +6270,9 @@ relation fun_clos_deftypes: `%%`(deftype*, deftype*) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 rule fun_clos_deftypes_case_1{`dt*` : deftype*, dt_n : deftype, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- if (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) - -- if (dt'#1*{dt'#1 <- `dt'*`} = var_1) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -6281,45 +6280,45 @@ 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, `dt*` : deftype*, var_1 : deftype*, var_0 : valtype}: `%%%`(C, t, var_0) + -- if (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) - -- if (dt#4*{dt#4 <- `dt*`} = var_1) ;; ../../../../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, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: `%%%`(C, dt, var_0) + -- if (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) - -- if (dt'#2*{dt'#2 <- `dt'*`} = var_1) ;; ../../../../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 rule fun_clos_tagtype_case_0{C : context, jt : typeuse, `dt*` : deftype*, var_1 : deftype*, var_0 : tagtype}: `%%%`(C, jt, var_0) + -- if (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) - -- if (dt#5*{dt#5 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rule fun_clos_externtype_case_0{C : context, xt : externtype, `dt*` : deftype*, var_1 : deftype*, var_0 : externtype}: `%%%`(C, xt, var_0) + -- if (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) - -- if (dt#6*{dt#6 <- `dt*`} = var_1) ;; ../../../../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, `dt*` : deftype*, var_1 : deftype*, var_0 : moduletype}: `%%%`(C, mmt, var_0) + -- if (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) - -- if (dt#7*{dt#7 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -7273,13 +7272,11 @@ relation fun_default__before_fun_default__case_7: `%`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_3{var_0 : fN}: `%`(F64_valtype) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_2{var_0 : fN}: `%`(F32_valtype) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -7307,14 +7304,14 @@ relation fun_default_: `%%`(valtype, val??) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_2{var_0 : fN}: `%%`(F32_valtype, ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))))) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_3{var_0 : fN}: `%%`(F64_valtype, ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))))) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_4: @@ -8854,8 +8851,8 @@ relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec 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) -- 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*`}))) + -- 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) @@ -9088,14 +9085,14 @@ relation fun_zero: `%%`(lanetype, lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_zero_case_4{var_0 : fN}: `%%`(F32_lanetype, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_zero_case_5{var_0 : fN}: `%%`(F64_lanetype, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -9151,9 +9148,9 @@ relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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)) + -- wf_uN: `%%`(N, `%`_uN(var_0)) -- fun_signed_: `%%%`(M, ($proj_uN_0(i).0 \ (2 ^ M)), var_1) -- fun_inv_signed_: `%%%`(N, var_1, var_0) - -- wf_uN: `%%`(N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN @@ -9191,17 +9188,17 @@ relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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) - -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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))) + -- wf_uN: `%%`(N, `%`_uN(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) - -- wf_uN: `%%`(N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) @@ -9221,11 +9218,11 @@ relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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))) + -- wf_uN: `%%`(N, `%`_uN(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) - -- wf_uN: `%%`(N, `%`_uN(var_0)) - -- if ((j_1 = var_1) /\ (j_2 = var_2)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -9659,14 +9656,14 @@ relation fun_unop_: `%%%%`(numtype, unop_, num_, num_*) ;; ../../../../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) -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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) -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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}: @@ -9773,26 +9770,26 @@ relation fun_binop_: `%%%%%`(numtype, binop_, num_, num_, num_*) ;; ../../../../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#30)*{iter_0#30 <- lift(var_0)}) - -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- 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#32)*{iter_0#32 <- lift(var_0)}) - -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- 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#34)*{iter_0#34 <- lift(var_0)}) - -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- 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 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#36)*{iter_0#36 <- lift(var_0)}) - -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- 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}: @@ -12241,9 +12238,6 @@ 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, `c_1*` : lane_*, `c**` : lane_**, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1, v) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M))), c_1#169))*{c_1#169 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#303))*{c#303 <- `c*#43`}*{`c*#43` <- `c**`} @@ -12253,12 +12247,13 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c_1#170*{c_1#170 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M)), v_1)) -- if (c#304*{c#304 <- `c*#44`}*{`c*#44` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`})) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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, `c_1*` : lane_*, `c**` : lane_**, `var_1*` : lane_**, var_0 : half?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `c_1*`} - -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#172))*{c_1#172 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#306))*{c#306 <- `c*#46`}*{`c*#46` <- `c**`} @@ -12268,13 +12263,12 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c_1#173*{c_1#173 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)[$half(half, 0, M_2) : M_2]) -- if (c#307*{c#307 <- `c*#47`}*{`c*#47` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`})) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `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, `c_1*` : lane_*, `c**` : lane_**, var_2 : lane_, `var_1*` : lane_**, var_0 : zero?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) - -- fun_zero: `%%`(Lnn_2, var_2) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `c_1*`} - -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#175))*{c_1#175 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#309))*{c#309 <- `c*#49`}*{`c*#49` <- `c**`} @@ -12284,6 +12278,9 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c_1#176*{c_1#176 <- `c_1*`} = $lanes_(`%X%`_shape(Lnn_1, `%`_dim(M_1)), v_1)) -- if (c#310*{c#310 <- `c*#50`}*{`c*#50` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [var_2]^M_1{})) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}) + -- fun_zero: `%%`(Lnn_2, var_2) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `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_) @@ -12332,26 +12329,26 @@ 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- 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_) @@ -12370,8 +12367,8 @@ 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#129110*{i#129110 <- `i*`}, v_1, v_2, var_0) - -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + -- 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_) @@ -13539,9 +13536,6 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13557,13 +13551,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13579,13 +13573,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13601,13 +13595,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13623,13 +13617,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13645,13 +13639,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13667,13 +13661,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13689,13 +13683,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13711,13 +13705,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13733,13 +13727,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13755,13 +13749,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13777,13 +13771,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13799,13 +13793,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13821,13 +13815,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13843,13 +13837,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13865,13 +13859,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13887,6 +13881,9 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c' = var_0) -- if (c'' = var_1) -- if (c <- var_2) + -- 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 = @@ -18007,14 +18004,14 @@ relation fun_alloctypes: `%%`(type*, deftype*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 rule fun_alloctypes_case_1{`type'*` : type*, type : type, `deftype'*` : deftype*, `deftype*` : deftype*, rectype : rectype, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) - -- 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) -- wf_uN: `%%`(32, x) -- if (deftype'#1*{deftype'#1 <- `deftype'*`} = var_0) -- if (type = TYPE_type(rectype)) -- if (deftype#1*{deftype#1 <- `deftype*`} = var_1) -- if ($proj_uN_0(x).0 = |deftype'#3*{deftype'#3 <- `deftype'*`}|) + -- 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 @@ -18038,12 +18035,12 @@ relation fun_alloctags: `%%%`(store, tagtype*, (store, tagaddr*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 rule fun_alloctags_case_1{s : store, tagtype : typeuse, `tagtype'*` : tagtype*, s_2 : store, ja : nat, `ja'*` : tagaddr*, s_1 : store, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) - -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) - -- fun_alloctag: `%%%`(s, tagtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ja) = var_0) -- if ((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 @@ -18067,12 +18064,12 @@ 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_1{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*, s_2 : store, ga : nat, `ga'*` : globaladdr*, s_1 : store, 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'*`})) - -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) - -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ga) = var_0) -- if ((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 @@ -18096,12 +18093,12 @@ relation fun_allocmems: `%%%`(store, memtype*, (store, memaddr*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 rule fun_allocmems_case_1{s : store, memtype : memtype, `memtype'*` : memtype*, s_2 : store, ma : nat, `ma'*` : memaddr*, s_1 : store, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) - -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) - -- fun_allocmem: `%%%`(s, memtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ma) = var_0) -- if ((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 @@ -18125,12 +18122,12 @@ 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_1{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*, s_2 : store, ta : nat, `ta'*` : tableaddr*, s_1 : store, 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'*`})) - -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) - -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ta) = var_0) -- if ((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 @@ -18154,12 +18151,12 @@ relation fun_allocfuncs: `%%%%%`(store, deftype*, funccode*, moduleinst*, (store ;; ../../../../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*, s_2 : store, fa : nat, `fa'*` : funcaddr*, s_1 : store, 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'*`})) - -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, fa) = var_0) -- if ((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 @@ -18183,12 +18180,12 @@ 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_1{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**, s_2 : store, da : nat, `da'*` : dataaddr*, s_1 : store, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: `%%%%`(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'*`})) - -- 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#11*{b#11 <- `b*`}, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, da) = var_0) -- if ((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#11*{b#11 <- `b*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -18212,12 +18209,12 @@ 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_1{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**, s_2 : store, ea : nat, `ea'*` : elemaddr*, s_1 : store, 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'*`})) - -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ea) = var_0) -- if ((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 @@ -18259,25 +18256,6 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_18 : 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)) - -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) - -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) - -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) - -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `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#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} - -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) - -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `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#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} - -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) - -- fun_alloctypes: `%%`(type#4*{type#4 <- `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) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(moduleinst) -- wf_store: `%`(s_1) @@ -18320,6 +18298,25 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_17) -- if (xi#2*{xi#2 <- `xi*`} = var_18) -- if (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_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `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#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `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#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `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 fun_rundata_: `%%%`(dataidx, data, instr*) @@ -18366,13 +18363,13 @@ relation fun_evalexprs: `%%%`(state, expr*, (state, ref*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 rule fun_evalexprs_case_1{z : state, expr : instr*, `expr'*` : expr*, z'' : state, ref : ref, `ref'*` : ref*, z' : state, var_0 : (state, ref*)}: `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) - -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) -- wf_state: `%`(z'') -- wf_ref: `%`(ref) -- (wf_ref: `%`(ref'#5))*{ref'#5 <- `ref'*`} -- wf_state: `%`(z') -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) -- if ((z'', ref'#6*{ref'#6 <- `ref'*`}) = var_0) + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -18387,14 +18384,14 @@ relation fun_evalexprss: `%%%`(state, expr**, (state, ref**)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 rule fun_evalexprss_case_1{z : state, `expr*` : expr*, `expr'**` : expr**, z'' : state, `ref*` : ref*, `ref'**` : ref**, z' : state, 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'**`})) - -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) - -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) -- wf_state: `%`(z'') -- (wf_ref: `%`(ref#6))*{ref#6 <- `ref*`} -- (wf_ref: `%`(ref'#7))*{ref'#7 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`} -- wf_state: `%`(z') -- if ((z', ref#7*{ref#7 <- `ref*`}) = var_0) -- if ((z'', ref'#8*{ref'#8 <- `ref'*#4`}*{`ref'*#4` <- `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 @@ -18409,8 +18406,6 @@ 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_1{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, z'' : state, val : val, `val'*` : val*, z' : state, s : store, f : frame, s' : store, a : nat, 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'*`})) - -- 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) -- wf_state: `%`(z'') -- wf_val: `%`(val) -- (wf_val: `%`(val'#3))*{val'#3 <- `val'*`} @@ -18421,6 +18416,8 @@ relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) -- if (z' = `%;%`_state(s, f)) -- if ((s', a) = var_0) -- if ((z'', val'#4*{val'#4 <- `val'*`}) = var_1) + -- 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 @@ -18428,18 +18425,6 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_11*` : instr**, `var_10*` : instr**, var_9 : (store, moduleinst), var_8 : (state, ref**), var_7 : (state, ref*), var_6 : (state, val*), var_5 : funcaddr*, var_4 : globaladdr*, var_3 : deftype*, 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?`}))) - -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} - -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} - -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) - -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) - -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) - -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) - -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) - -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) - -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) - -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) - -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) - -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') -- (wf_val: `%`(val_G#3))*{val_G#3 <- `val_G*`} @@ -18479,6 +18464,18 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_10^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`})) -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_11^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`})) -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) + -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) + -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec relation fun_invoke: `%%%%`(store, funcaddr, val*, config) @@ -18922,8 +18919,8 @@ relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: `%%`(decl#1*{decl#1 <- `decl*`}, true) - -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) -- if (var_0 = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec 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*}: diff --git a/spectec/test-middlend/specification.exp/10-sideconditions.il b/spectec/test-middlend/specification.exp/10-sideconditions.il index b3f95eeb4c..70c48d059a 100644 --- a/spectec/test-middlend/specification.exp/10-sideconditions.il +++ b/spectec/test-middlend/specification.exp/10-sideconditions.il @@ -420,35 +420,35 @@ relation fun_utf8: `%%`(char*, byte*) ;; ../../../../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]) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(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]) - -- fun_cont: `%%`(b_3, var_1) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(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]) - -- fun_cont: `%%`(b_4, var_2) - -- fun_cont: `%%`(b_3, var_1) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(b_3) -- wf_byte: `%`(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 @@ -1936,28 +1936,27 @@ relation fun_subst_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.6-401.17 relation fun_minus_recs_before_fun_minus_recs_case_3: `%%`(typevar*, typeuse*) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%`([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) - -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} -- wf_typevar: `%`(_IDX_typevar(x)) -- if (var_0 =/= ?()) -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_0: `%%`([], []) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 @@ -1972,12 +1971,12 @@ relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, 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'*`}))) - -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} -- wf_typevar: `%`(_IDX_typevar(x)) -- if (var_0 =/= ?()) -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 rule fun_minus_recs_case_3{x0 : typevar*, x1 : typeuse*}: @@ -2050,9 +2049,9 @@ 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_1 : heaptype, 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)) + -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) -- fun_subst_heaptype: `%%%%`(ht, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, var_1) -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 relation fun_subst_valtype: `%%%%`(valtype, typevar*, typeuse*, valtype) @@ -2136,31 +2135,32 @@ 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_1 : storagetype, var_0 : storagetype}: `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) -- fun_subst_storagetype: `%%%%`(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, var_1) -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) ;; ../../../../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_1*` : fieldtype*, `var_0*` : fieldtype*}: `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) -- if (|`var_1*`| = |`ft*`|) -- (fun_subst_fieldtype: `%%%%`(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, var_1))*{var_1 <- `var_1*`, ft#2 <- `ft*`} -- if (|`var_0*`| = |`ft*`|) -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) ;; ../../../../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_1 : fieldtype, var_0 : fieldtype}: `%%%%`(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, ARRAY_comptype(var_0)) + -- wf_comptype: `%`(ARRAY_comptype(var_1)) -- fun_subst_fieldtype: `%%%%`(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}, var_1) -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_comptype: `%`(ARRAY_comptype(var_1)) ;; ../../../../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_3*` : valtype*, `var_2*` : valtype*, `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#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) -- if (|`var_3*`| = |`t_2*`|) -- (fun_subst_valtype: `%%%%`(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_3))*{var_3 <- `var_3*`, t_2#2 <- `t_2*`} -- if (|`var_2*`| = |`t_1*`|) @@ -2169,33 +2169,32 @@ relation fun_subst_comptype: `%%%%`(comptype, typevar*, typeuse*, comptype) -- (fun_subst_valtype: `%%%%`(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, t_2 <- `t_2*`} -- if (|`var_0*`| = |`t_1*`|) -- (fun_subst_valtype: `%%%%`(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, t_1 <- `t_1*`} - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) ;; ../../../../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_3 : comptype, `var_2*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#4*{tu'#4 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) -- fun_subst_comptype: `%%%%`(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, var_3) -- if (|`var_2*`| = |`tu'*`|) -- (fun_subst_typeuse: `%%%%`(tu'#5, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}, var_2))*{var_2 <- `var_2*`, tu'#5 <- `tu'*`} -- fun_subst_comptype: `%%%%`(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1) -- if (|`var_0*`| = |`tu'*`|) -- (fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, tu' <- `tu'*`} - -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) ;; ../../../../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*, `tv'*` : typevar*, `tu'*` : typeuse*, var_1 : (typevar*, typeuse*)?, `var_0*` : subtype*}: `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) - -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) - -- if (|`var_0*`| = |`st*`|) - -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} -- (wf_typevar: `%`(tv'#4))*{tv'#4 <- `tv'*`} -- (wf_typeuse: `%`(tu'#6))*{tu'#6 <- `tu'*`} -- if (var_1 =/= ?()) -- if ((tv'#5*{tv'#5 <- `tv'*`}, tu'#7*{tu'#7 <- `tu'*`}) = !(var_1)) + -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) + -- if (|`var_0*`| = |`st*`|) + -- (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) @@ -2222,9 +2221,9 @@ relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : valtype, var_0 : valtype}: `%%%%`(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) -- fun_subst_valtype: `%%%%`(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}, var_1) -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation fun_subst_memtype: `%%%%`(memtype, typevar*, typeuse*, memtype) @@ -2238,52 +2237,53 @@ 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_1 : reftype, var_0 : reftype}: `%%%%`(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) -- fun_subst_reftype: `%%%%`(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}, var_1) -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) ;; ../../../../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_1 : tagtype, var_0 : tagtype}: `%%%%`(TAG_externtype(jt), tv#75*{tv#75 <- `tv*`}, tu#75*{tu#75 <- `tu*`}, TAG_externtype(var_0)) + -- wf_externtype: `%`(TAG_externtype(var_1)) -- fun_subst_tagtype: `%%%%`(jt, tv#76*{tv#76 <- `tv*`}, tu#76*{tu#76 <- `tu*`}, var_1) -- fun_subst_tagtype: `%%%%`(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(TAG_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_1{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : globaltype, var_0 : globaltype}: `%%%%`(GLOBAL_externtype(gt), tv#77*{tv#77 <- `tv*`}, tu#77*{tu#77 <- `tu*`}, GLOBAL_externtype(var_0)) + -- wf_externtype: `%`(GLOBAL_externtype(var_1)) -- fun_subst_globaltype: `%%%%`(gt, tv#78*{tv#78 <- `tv*`}, tu#78*{tu#78 <- `tu*`}, var_1) -- fun_subst_globaltype: `%%%%`(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(GLOBAL_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_2{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : tabletype, var_0 : tabletype}: `%%%%`(TABLE_externtype(tt), tv#79*{tv#79 <- `tv*`}, tu#79*{tu#79 <- `tu*`}, TABLE_externtype(var_0)) + -- wf_externtype: `%`(TABLE_externtype(var_1)) -- fun_subst_tabletype: `%%%%`(tt, tv#80*{tv#80 <- `tv*`}, tu#80*{tu#80 <- `tu*`}, var_1) -- fun_subst_tabletype: `%%%%`(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(TABLE_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_3{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : memtype, var_0 : memtype}: `%%%%`(MEM_externtype(mt), tv#81*{tv#81 <- `tv*`}, tu#81*{tu#81 <- `tu*`}, MEM_externtype(var_0)) + -- wf_externtype: `%`(MEM_externtype(var_1)) -- fun_subst_memtype: `%%%%`(mt, tv#82*{tv#82 <- `tv*`}, tu#82*{tu#82 <- `tu*`}, var_1) -- fun_subst_memtype: `%%%%`(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(MEM_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_4{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_1 : typeuse, var_0 : typeuse}: `%%%%`(FUNC_externtype(tu'), tv#83*{tv#83 <- `tv*`}, tu#83*{tu#83 <- `tu*`}, FUNC_externtype(var_0)) + -- wf_externtype: `%`(FUNC_externtype(var_1)) -- fun_subst_typeuse: `%%%%`(tu', tv#84*{tv#84 <- `tv*`}, tu#84*{tu#84 <- `tu*`}, var_1) -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(FUNC_externtype(var_1)) ;; ../../../../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_3*` : externtype*, `var_2*` : externtype*, `var_1*` : externtype*, `var_0*` : externtype*}: `%%%%`(`%->%`_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(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) -- if (|`var_3*`| = |`xt_2*`|) -- (fun_subst_externtype: `%%%%`(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`}, var_3))*{var_3 <- `var_3*`, xt_2#2 <- `xt_2*`} -- if (|`var_2*`| = |`xt_1*`|) @@ -2292,79 +2292,78 @@ relation fun_subst_moduletype: `%%%%`(moduletype, typevar*, typeuse*, moduletype -- (fun_subst_externtype: `%%%%`(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, xt_2 <- `xt_2*`} -- if (|`var_0*`| = |`xt_1*`|) -- (fun_subst_externtype: `%%%%`(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, xt_1 <- `xt_1*`} - -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) ;; ../../../../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#88^n{tu#88 <- `tu*`}, var_0) - -- fun_subst_valtype: `%%%%`(t, _IDX_typevar(`%`_typeidx(i))^(i int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) - -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -5839,12 +5838,12 @@ 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*, free : free, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- wf_free: `%`(free) + -- if (free = var_1) -- if (|`var_2*`| = |`instr*`|) -- (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) - -- wf_free: `%`(free) - -- if (free = var_1) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -6322,9 +6321,9 @@ relation fun_clos_deftypes: `%%`(deftype*, deftype*) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 rule fun_clos_deftypes_case_1{`dt*` : deftype*, dt_n : deftype, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- if (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) - -- if (dt'#1*{dt'#1 <- `dt'*`} = var_1) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -6332,45 +6331,45 @@ 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, `dt*` : deftype*, var_1 : deftype*, var_0 : valtype}: `%%%`(C, t, var_0) + -- if (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) - -- if (dt#4*{dt#4 <- `dt*`} = var_1) ;; ../../../../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, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: `%%%`(C, dt, var_0) + -- if (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) - -- if (dt'#2*{dt'#2 <- `dt'*`} = var_1) ;; ../../../../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 rule fun_clos_tagtype_case_0{C : context, jt : typeuse, `dt*` : deftype*, var_1 : deftype*, var_0 : tagtype}: `%%%`(C, jt, var_0) + -- if (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) - -- if (dt#5*{dt#5 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rule fun_clos_externtype_case_0{C : context, xt : externtype, `dt*` : deftype*, var_1 : deftype*, var_0 : externtype}: `%%%`(C, xt, var_0) + -- if (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) - -- if (dt#6*{dt#6 <- `dt*`} = var_1) ;; ../../../../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, `dt*` : deftype*, var_1 : deftype*, var_0 : moduletype}: `%%%`(C, mmt, var_0) + -- if (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) - -- if (dt#7*{dt#7 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -7361,13 +7360,11 @@ relation fun_default__before_fun_default__case_7: `%`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_3{var_0 : fN}: `%`(F64_valtype) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_2{var_0 : fN}: `%`(F32_valtype) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -7395,14 +7392,14 @@ relation fun_default_: `%%`(valtype, val??) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_2{var_0 : fN}: `%%`(F32_valtype, ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))))) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_3{var_0 : fN}: `%%`(F64_valtype, ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))))) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_4: @@ -9039,8 +9036,8 @@ relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec 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) -- 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*`}))) + -- 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) @@ -9282,14 +9279,14 @@ relation fun_zero: `%%`(lanetype, lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_zero_case_4{var_0 : fN}: `%%`(F32_lanetype, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_zero_case_5{var_0 : fN}: `%%`(F64_lanetype, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -9345,9 +9342,9 @@ relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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)) + -- wf_uN: `%%`(N, `%`_uN(var_0)) -- fun_signed_: `%%%`(M, ($proj_uN_0(i).0 \ (2 ^ M)), var_1) -- fun_inv_signed_: `%%%`(N, var_1, var_0) - -- wf_uN: `%%`(N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN @@ -9385,17 +9382,17 @@ relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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) - -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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))) + -- wf_uN: `%%`(N, `%`_uN(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) - -- wf_uN: `%%`(N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) @@ -9415,11 +9412,11 @@ relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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))) + -- wf_uN: `%%`(N, `%`_uN(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) - -- wf_uN: `%%`(N, `%`_uN(var_0)) - -- if ((j_1 = var_1) /\ (j_2 = var_2)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -9855,14 +9852,14 @@ relation fun_unop_: `%%%%`(numtype, unop_, num_, num_*) ;; ../../../../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) -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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) -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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}: @@ -9969,26 +9966,26 @@ relation fun_binop_: `%%%%%`(numtype, binop_, num_, num_, num_*) ;; ../../../../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#30)*{iter_0#30 <- lift(var_0)}) - -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- 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#32)*{iter_0#32 <- lift(var_0)}) - -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- 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#34)*{iter_0#34 <- lift(var_0)}) - -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- 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 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#36)*{iter_0#36 <- lift(var_0)}) - -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- 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}: @@ -12449,10 +12446,6 @@ 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, `c_1*` : lane_*, `c**` : lane_**, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1, v) - -- if (|`var_2*`| = |`c_1*`|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M))), c_1#169))*{c_1#169 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#303))*{c#303 <- `c*#43`}*{`c*#43` <- `c**`} @@ -12463,13 +12456,14 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c#304*{c#304 <- `c*#44`}*{`c*#44` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`})) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}) + -- if (|`var_2*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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, `c_1*` : lane_*, `c**` : lane_**, `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_1*`| = |`c_1*`|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `c_1*`} - -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#172))*{c_1#172 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#306))*{c#306 <- `c*#46`}*{`c*#46` <- `c**`} @@ -12480,14 +12474,13 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c#307*{c#307 <- `c*#47`}*{`c*#47` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`})) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}) + -- if (|`var_1*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `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, `c_1*` : lane_*, `c**` : lane_**, var_2 : lane_, `var_1*` : lane_**, var_0 : zero?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) - -- fun_zero: `%%`(Lnn_2, var_2) - -- if (|`var_1*`| = |`c_1*`|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `c_1*`} - -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#175))*{c_1#175 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#309))*{c#309 <- `c*#49`}*{`c*#49` <- `c**`} @@ -12498,6 +12491,10 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c#310*{c#310 <- `c*#50`}*{`c*#50` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [var_2]^M_1{})) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}) + -- fun_zero: `%%`(Lnn_2, var_2) + -- if (|`var_1*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `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_) @@ -12546,26 +12543,26 @@ 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- 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_) @@ -12584,8 +12581,8 @@ 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#129110*{i#129110 <- `i*`}, v_1, v_2, var_0) - -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + -- 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_) @@ -13785,9 +13782,6 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13804,13 +13798,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13827,13 +13821,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13850,13 +13844,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13873,13 +13867,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13896,13 +13890,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13919,13 +13913,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13942,13 +13936,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13965,13 +13959,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13988,13 +13982,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14011,13 +14005,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14034,13 +14028,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14057,13 +14051,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14080,13 +14074,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14103,13 +14097,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14126,13 +14120,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14149,6 +14143,9 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 = @@ -18510,14 +18507,14 @@ relation fun_alloctypes: `%%`(type*, deftype*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 rule fun_alloctypes_case_1{`type'*` : type*, type : type, `deftype'*` : deftype*, `deftype*` : deftype*, rectype : rectype, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) - -- 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) -- wf_uN: `%%`(32, x) -- if (deftype'#1*{deftype'#1 <- `deftype'*`} = var_0) -- if (type = TYPE_type(rectype)) -- if (deftype#1*{deftype#1 <- `deftype*`} = var_1) -- if ($proj_uN_0(x).0 = |deftype'#3*{deftype'#3 <- `deftype'*`}|) + -- 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 @@ -18541,12 +18538,12 @@ relation fun_alloctags: `%%%`(store, tagtype*, (store, tagaddr*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 rule fun_alloctags_case_1{s : store, tagtype : typeuse, `tagtype'*` : tagtype*, s_2 : store, ja : nat, `ja'*` : tagaddr*, s_1 : store, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) - -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) - -- fun_alloctag: `%%%`(s, tagtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ja) = var_0) -- if ((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 @@ -18570,12 +18567,12 @@ 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_1{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*, s_2 : store, ga : nat, `ga'*` : globaladdr*, s_1 : store, 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'*`})) - -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) - -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ga) = var_0) -- if ((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 @@ -18599,12 +18596,12 @@ relation fun_allocmems: `%%%`(store, memtype*, (store, memaddr*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 rule fun_allocmems_case_1{s : store, memtype : memtype, `memtype'*` : memtype*, s_2 : store, ma : nat, `ma'*` : memaddr*, s_1 : store, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) - -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) - -- fun_allocmem: `%%%`(s, memtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ma) = var_0) -- if ((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 @@ -18628,12 +18625,12 @@ 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_1{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*, s_2 : store, ta : nat, `ta'*` : tableaddr*, s_1 : store, 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'*`})) - -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) - -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ta) = var_0) -- if ((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 @@ -18657,12 +18654,12 @@ relation fun_allocfuncs: `%%%%%`(store, deftype*, funccode*, moduleinst*, (store ;; ../../../../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*, s_2 : store, fa : nat, `fa'*` : funcaddr*, s_1 : store, 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'*`})) - -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, fa) = var_0) -- if ((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 @@ -18686,12 +18683,12 @@ 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_1{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**, s_2 : store, da : nat, `da'*` : dataaddr*, s_1 : store, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: `%%%%`(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'*`})) - -- 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#11*{b#11 <- `b*`}, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, da) = var_0) -- if ((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#11*{b#11 <- `b*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -18715,12 +18712,12 @@ 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_1{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**, s_2 : store, ea : nat, `ea'*` : elemaddr*, s_1 : store, 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'*`})) - -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ea) = var_0) -- if ((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 @@ -18768,31 +18765,6 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_18 : 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)) - -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) - -- (if ($proj_uN_0(x#4).0 < |dt#15*{dt#15 <- `dt*`}|))*{x#4 <- `x*`} - -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) - -- if (|`var_16*`| = |`elemtype*`|) - -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) - -- if (|`var_13*`| = |`tabletype*`|) - -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `tabletype*`} - -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) - -- if (|`var_11*`| = |`memtype*`|) - -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} - -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) - -- if (|`var_9*`| = |`globaltype*`|) - -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `globaltype*`} - -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) - -- if (|`var_7*`| = |`tagtype*`|) - -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} - -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) - -- fun_alloctypes: `%%`(type#4*{type#4 <- `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) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(moduleinst) -- wf_store: `%`(s_1) @@ -18842,6 +18814,31 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_17) -- if (xi#2*{xi#2 <- `xi*`} = var_18) -- if (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_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) + -- (if ($proj_uN_0(x#4).0 < |dt#15*{dt#15 <- `dt*`}|))*{x#4 <- `x*`} + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) + -- if (|`var_16*`| = |`elemtype*`|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) + -- if (|`var_13*`| = |`tabletype*`|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `tabletype*`} + -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) + -- if (|`var_11*`| = |`memtype*`|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- if (|`var_9*`| = |`globaltype*`|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `globaltype*`} + -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) + -- if (|`var_7*`| = |`tagtype*`|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `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 fun_rundata_: `%%%`(dataidx, data, instr*) @@ -18888,13 +18885,13 @@ relation fun_evalexprs: `%%%`(state, expr*, (state, ref*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 rule fun_evalexprs_case_1{z : state, expr : instr*, `expr'*` : expr*, z'' : state, ref : ref, `ref'*` : ref*, z' : state, var_0 : (state, ref*)}: `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) - -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) -- wf_state: `%`(z'') -- wf_ref: `%`(ref) -- (wf_ref: `%`(ref'#5))*{ref'#5 <- `ref'*`} -- wf_state: `%`(z') -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) -- if ((z'', ref'#6*{ref'#6 <- `ref'*`}) = var_0) + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -18909,14 +18906,14 @@ relation fun_evalexprss: `%%%`(state, expr**, (state, ref**)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 rule fun_evalexprss_case_1{z : state, `expr*` : expr*, `expr'**` : expr**, z'' : state, `ref*` : ref*, `ref'**` : ref**, z' : state, 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'**`})) - -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) - -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) -- wf_state: `%`(z'') -- (wf_ref: `%`(ref#6))*{ref#6 <- `ref*`} -- (wf_ref: `%`(ref'#7))*{ref'#7 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`} -- wf_state: `%`(z') -- if ((z', ref#7*{ref#7 <- `ref*`}) = var_0) -- if ((z'', ref'#8*{ref'#8 <- `ref'*#4`}*{`ref'*#4` <- `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 @@ -18931,8 +18928,6 @@ 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_1{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, z'' : state, val : val, `val'*` : val*, z' : state, s : store, f : frame, s' : store, a : nat, 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'*`})) - -- 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) -- wf_state: `%`(z'') -- wf_val: `%`(val) -- (wf_val: `%`(val'#3))*{val'#3 <- `val'*`} @@ -18943,6 +18938,8 @@ relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) -- if (z' = `%;%`_state(s, f)) -- if ((s', a) = var_0) -- if ((z'', val'#4*{val'#4 <- `val'*`}) = var_1) + -- 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 @@ -18950,20 +18947,6 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_11*` : instr**, `var_10*` : instr**, var_9 : (store, moduleinst), var_8 : (state, ref**), var_7 : (state, ref*), var_6 : (state, val*), var_5 : funcaddr*, var_4 : globaladdr*, var_3 : deftype*, 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?`}))) - -- (if (i_E#2 < |elem#12*{elem#12 <- `elem*`}|))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} - -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} - -- (if (i_D#2 < |data#11*{data#11 <- `data*`}|))^(i_D#2<|data#10*{data#10 <- `data*`}|){} - -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} - -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) - -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) - -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) - -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) - -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) - -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) - -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) - -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) - -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) - -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') -- (wf_val: `%`(val_G#3))*{val_G#3 <- `val_G*`} @@ -19009,6 +18992,20 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_10^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`})) -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_11^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`})) -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) + -- (if (i_E#2 < |elem#12*{elem#12 <- `elem*`}|))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} + -- (if (i_D#2 < |data#11*{data#11 <- `data*`}|))^(i_D#2<|data#10*{data#10 <- `data*`}|){} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) + -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) + -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec relation fun_invoke: `%%%%`(store, funcaddr, val*, config) @@ -19454,8 +19451,8 @@ relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: `%%`(decl#1*{decl#1 <- `decl*`}, true) - -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) -- if (var_0 = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec 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*}: diff --git a/spectec/test-middlend/specification.exp/11-alias-demut.il b/spectec/test-middlend/specification.exp/11-alias-demut.il index 0f29962e0d..0236d7322a 100644 --- a/spectec/test-middlend/specification.exp/11-alias-demut.il +++ b/spectec/test-middlend/specification.exp/11-alias-demut.il @@ -420,35 +420,35 @@ relation fun_utf8: `%%`(char*, byte*) ;; ../../../../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]) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(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]) - -- fun_cont: `%%`(b_3, var_1) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(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]) - -- fun_cont: `%%`(b_4, var_2) - -- fun_cont: `%%`(b_3, var_1) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(b_3) -- wf_byte: `%`(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 @@ -1936,28 +1936,27 @@ relation fun_subst_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.6-401.17 relation fun_minus_recs_before_fun_minus_recs_case_3: `%%`(typevar*, typeuse*) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%`([_IDX_typevar(x)] ++ tv#2*{tv#2 <- `tv*`}, [tu_1] ++ tu#2*{tu#2 <- `tu*`}) - -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} -- wf_typevar: `%`(_IDX_typevar(x)) -- if (var_0 =/= ?()) -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_1{n : nat, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%`([REC_typevar(n)] ++ tv#1*{tv#1 <- `tv*`}, [tu_1] ++ tu#1*{tu#1 <- `tu*`}) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_0: `%%`([], []) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 @@ -1972,12 +1971,12 @@ relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 rule fun_minus_recs_case_2{x : uN, `tv*` : typevar*, tu_1 : typeuse, `tu*` : typeuse*, `tv'*` : typevar*, `tu'*` : typeuse*, var_0 : (typevar*, 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'*`}))) - -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- `tv'*`} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- `tu'*`} -- wf_typevar: `%`(_IDX_typevar(x)) -- if (var_0 =/= ?()) -- if ((tv'#3*{tv'#3 <- `tv'*`}, tu'#3*{tu'#3 <- `tu'*`}) = !(var_0)) + -- fun_minus_recs: `%%%`(tv#3*{tv#3 <- `tv*`}, tu#3*{tu#3 <- `tu*`}, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 rule fun_minus_recs_case_3{x0 : typevar*, x1 : typeuse*}: @@ -2050,9 +2049,9 @@ 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_1 : heaptype, 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)) + -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) -- fun_subst_heaptype: `%%%%`(ht, tv#21*{tv#21 <- `tv*`}, tu#21*{tu#21 <- `tu*`}, var_1) -- fun_subst_heaptype: `%%%%`(ht, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_reftype: `%`(REF_reftype(null#2?{null#2 <- `null?`}, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 relation fun_subst_valtype: `%%%%`(valtype, typevar*, typeuse*, valtype) @@ -2136,31 +2135,32 @@ 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_1 : storagetype, var_0 : storagetype}: `%%%%`(`%%`_fieldtype(mut#1?{mut#1 <- `mut?`}, zt), tv#53*{tv#53 <- `tv*`}, tu#53*{tu#53 <- `tu*`}, `%%`_fieldtype(mut?{mut <- `mut?`}, var_0)) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) -- fun_subst_storagetype: `%%%%`(zt, tv#54*{tv#54 <- `tv*`}, tu#54*{tu#54 <- `tu*`}, var_1) -- fun_subst_storagetype: `%%%%`(zt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut#2?{mut#2 <- `mut?`}, var_1)) ;; ../../../../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_1*` : fieldtype*, `var_0*` : fieldtype*}: `%%%%`(STRUCT_comptype(`%`_list(ft#1*{ft#1 <- `ft*`})), tv#55*{tv#55 <- `tv*`}, tu#55*{tu#55 <- `tu*`}, STRUCT_comptype(`%`_list(var_0*{var_0 <- `var_0*`}))) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) -- if (|`var_1*`| = |`ft*`|) -- (fun_subst_fieldtype: `%%%%`(ft#2, tv#56*{tv#56 <- `tv*`}, tu#56*{tu#56 <- `tu*`}, var_1))*{var_1 <- `var_1*`, ft#2 <- `ft*`} -- if (|`var_0*`| = |`ft*`|) -- (fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, ft <- `ft*`} - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1*{var_1 <- `var_1*`}))) ;; ../../../../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_1 : fieldtype, var_0 : fieldtype}: `%%%%`(ARRAY_comptype(ft), tv#57*{tv#57 <- `tv*`}, tu#57*{tu#57 <- `tu*`}, ARRAY_comptype(var_0)) + -- wf_comptype: `%`(ARRAY_comptype(var_1)) -- fun_subst_fieldtype: `%%%%`(ft, tv#58*{tv#58 <- `tv*`}, tu#58*{tu#58 <- `tu*`}, var_1) -- fun_subst_fieldtype: `%%%%`(ft, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_comptype: `%`(ARRAY_comptype(var_1)) ;; ../../../../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_3*` : valtype*, `var_2*` : valtype*, `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#59*{tv#59 <- `tv*`}, tu#59*{tu#59 <- `tu*`}, `FUNC%->%`_comptype(`%`_resulttype(var_0*{var_0 <- `var_0*`}), `%`_resulttype(var_1*{var_1 <- `var_1*`}))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) -- if (|`var_3*`| = |`t_2*`|) -- (fun_subst_valtype: `%%%%`(t_2#2, tv#61*{tv#61 <- `tv*`}, tu#61*{tu#61 <- `tu*`}, var_3))*{var_3 <- `var_3*`, t_2#2 <- `t_2*`} -- if (|`var_2*`| = |`t_1*`|) @@ -2169,33 +2169,32 @@ relation fun_subst_comptype: `%%%%`(comptype, typevar*, typeuse*, comptype) -- (fun_subst_valtype: `%%%%`(t_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, t_2 <- `t_2*`} -- if (|`var_0*`| = |`t_1*`|) -- (fun_subst_valtype: `%%%%`(t_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, t_1 <- `t_1*`} - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2*{var_2 <- `var_2*`}), `%`_resulttype(var_3*{var_3 <- `var_3*`}))) ;; ../../../../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_3 : comptype, `var_2*` : typeuse*, var_1 : comptype, `var_0*` : typeuse*}: `%%%%`(SUB_subtype(final#1?{final#1 <- `final?`}, tu'#4*{tu'#4 <- `tu'*`}, ct), tv#62*{tv#62 <- `tv*`}, tu#62*{tu#62 <- `tu*`}, SUB_subtype(final?{final <- `final?`}, var_0*{var_0 <- `var_0*`}, var_1)) + -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) -- fun_subst_comptype: `%%%%`(ct, tv#64*{tv#64 <- `tv*`}, tu#64*{tu#64 <- `tu*`}, var_3) -- if (|`var_2*`| = |`tu'*`|) -- (fun_subst_typeuse: `%%%%`(tu'#5, tv#63*{tv#63 <- `tv*`}, tu#63*{tu#63 <- `tu*`}, var_2))*{var_2 <- `var_2*`, tu'#5 <- `tu'*`} -- fun_subst_comptype: `%%%%`(ct, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1) -- if (|`var_0*`| = |`tu'*`|) -- (fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, tu' <- `tu'*`} - -- wf_subtype: `%`(SUB_subtype(final#2?{final#2 <- `final?`}, var_2*{var_2 <- `var_2*`}, var_3)) ;; ../../../../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*, `tv'*` : typevar*, `tu'*` : typeuse*, var_1 : (typevar*, typeuse*)?, `var_0*` : subtype*}: `%%%%`(REC_rectype(`%`_list(st#1*{st#1 <- `st*`})), tv#65*{tv#65 <- `tv*`}, tu#65*{tu#65 <- `tu*`}, REC_rectype(`%`_list(var_0*{var_0 <- `var_0*`}))) - -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) - -- if (|`var_0*`| = |`st*`|) - -- (fun_subst_subtype: `%%%%`(st, tv'*{tv' <- `tv'*`}, tu'*{tu' <- `tu'*`}, var_0))*{var_0 <- `var_0*`, st <- `st*`} -- (wf_typevar: `%`(tv'#4))*{tv'#4 <- `tv'*`} -- (wf_typeuse: `%`(tu'#6))*{tu'#6 <- `tu'*`} -- if (var_1 =/= ?()) -- if ((tv'#5*{tv'#5 <- `tv'*`}, tu'#7*{tu'#7 <- `tu'*`}) = !(var_1)) + -- fun_minus_recs: `%%%`(tv#66*{tv#66 <- `tv*`}, tu#66*{tu#66 <- `tu*`}, var_1) + -- if (|`var_0*`| = |`st*`|) + -- (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) @@ -2222,9 +2221,9 @@ relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_globaltype_case_0{`mut?` : mut?, t : valtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : valtype, var_0 : valtype}: `%%%%`(`%%`_globaltype(mut#3?{mut#3 <- `mut?`}, t), tv#70*{tv#70 <- `tv*`}, tu#70*{tu#70 <- `tu*`}, `%%`_globaltype(mut?{mut <- `mut?`}, var_0)) + -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) -- fun_subst_valtype: `%%%%`(t, tv#71*{tv#71 <- `tv*`}, tu#71*{tu#71 <- `tu*`}, var_1) -- fun_subst_valtype: `%%%%`(t, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_globaltype: `%`(`%%`_globaltype(mut#4?{mut#4 <- `mut?`}, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation fun_subst_memtype: `%%%%`(memtype, typevar*, typeuse*, memtype) @@ -2238,52 +2237,53 @@ 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_1 : reftype, var_0 : reftype}: `%%%%`(`%%%`_tabletype(at, lim, rt), tv#73*{tv#73 <- `tv*`}, tu#73*{tu#73 <- `tu*`}, `%%%`_tabletype(at, lim, var_0)) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) -- fun_subst_reftype: `%%%%`(rt, tv#74*{tv#74 <- `tv*`}, tu#74*{tu#74 <- `tu*`}, var_1) -- fun_subst_reftype: `%%%%`(rt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) ;; ../../../../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_1 : tagtype, var_0 : tagtype}: `%%%%`(TAG_externtype(jt), tv#75*{tv#75 <- `tv*`}, tu#75*{tu#75 <- `tu*`}, TAG_externtype(var_0)) + -- wf_externtype: `%`(TAG_externtype(var_1)) -- fun_subst_tagtype: `%%%%`(jt, tv#76*{tv#76 <- `tv*`}, tu#76*{tu#76 <- `tu*`}, var_1) -- fun_subst_tagtype: `%%%%`(jt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(TAG_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_1{gt : globaltype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : globaltype, var_0 : globaltype}: `%%%%`(GLOBAL_externtype(gt), tv#77*{tv#77 <- `tv*`}, tu#77*{tu#77 <- `tu*`}, GLOBAL_externtype(var_0)) + -- wf_externtype: `%`(GLOBAL_externtype(var_1)) -- fun_subst_globaltype: `%%%%`(gt, tv#78*{tv#78 <- `tv*`}, tu#78*{tu#78 <- `tu*`}, var_1) -- fun_subst_globaltype: `%%%%`(gt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(GLOBAL_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_2{tt : tabletype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : tabletype, var_0 : tabletype}: `%%%%`(TABLE_externtype(tt), tv#79*{tv#79 <- `tv*`}, tu#79*{tu#79 <- `tu*`}, TABLE_externtype(var_0)) + -- wf_externtype: `%`(TABLE_externtype(var_1)) -- fun_subst_tabletype: `%%%%`(tt, tv#80*{tv#80 <- `tv*`}, tu#80*{tu#80 <- `tu*`}, var_1) -- fun_subst_tabletype: `%%%%`(tt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(TABLE_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_3{mt : memtype, `tv*` : typevar*, `tu*` : typeuse*, var_1 : memtype, var_0 : memtype}: `%%%%`(MEM_externtype(mt), tv#81*{tv#81 <- `tv*`}, tu#81*{tu#81 <- `tu*`}, MEM_externtype(var_0)) + -- wf_externtype: `%`(MEM_externtype(var_1)) -- fun_subst_memtype: `%%%%`(mt, tv#82*{tv#82 <- `tv*`}, tu#82*{tu#82 <- `tu*`}, var_1) -- fun_subst_memtype: `%%%%`(mt, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(MEM_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_4{tu' : typeuse, `tv*` : typevar*, `tu*` : typeuse*, var_1 : typeuse, var_0 : typeuse}: `%%%%`(FUNC_externtype(tu'), tv#83*{tv#83 <- `tv*`}, tu#83*{tu#83 <- `tu*`}, FUNC_externtype(var_0)) + -- wf_externtype: `%`(FUNC_externtype(var_1)) -- fun_subst_typeuse: `%%%%`(tu', tv#84*{tv#84 <- `tv*`}, tu#84*{tu#84 <- `tu*`}, var_1) -- fun_subst_typeuse: `%%%%`(tu', tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0) - -- wf_externtype: `%`(FUNC_externtype(var_1)) ;; ../../../../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_3*` : externtype*, `var_2*` : externtype*, `var_1*` : externtype*, `var_0*` : externtype*}: `%%%%`(`%->%`_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(var_0*{var_0 <- `var_0*`}, var_1*{var_1 <- `var_1*`})) + -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) -- if (|`var_3*`| = |`xt_2*`|) -- (fun_subst_externtype: `%%%%`(xt_2#2, tv#87*{tv#87 <- `tv*`}, tu#87*{tu#87 <- `tu*`}, var_3))*{var_3 <- `var_3*`, xt_2#2 <- `xt_2*`} -- if (|`var_2*`| = |`xt_1*`|) @@ -2292,79 +2292,78 @@ relation fun_subst_moduletype: `%%%%`(moduletype, typevar*, typeuse*, moduletype -- (fun_subst_externtype: `%%%%`(xt_2, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_1))*{var_1 <- `var_1*`, xt_2 <- `xt_2*`} -- if (|`var_0*`| = |`xt_1*`|) -- (fun_subst_externtype: `%%%%`(xt_1, tv*{tv <- `tv*`}, tu*{tu <- `tu*`}, var_0))*{var_0 <- `var_0*`, xt_1 <- `xt_1*`} - -- wf_moduletype: `%`(`%->%`_moduletype(var_2*{var_2 <- `var_2*`}, var_3*{var_3 <- `var_3*`})) ;; ../../../../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#88^n{tu#88 <- `tu*`}, var_0) - -- fun_subst_valtype: `%%%%`(t, _IDX_typevar(`%`_typeidx(i))^(i int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) - -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + -- fun_shift_labelidxs: `%%`(labelidx'*{labelidx' <- `labelidx'*`}, var_0) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -5839,12 +5838,12 @@ 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*, free : free, `var_2*` : free*, var_1 : free, var_0 : labelidx*}: `%%`(instr#4*{instr#4 <- `instr*`}, free[LABELS_free = var_0]) + -- wf_free: `%`(free) + -- if (free = var_1) -- if (|`var_2*`| = |`instr*`|) -- (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) - -- wf_free: `%`(free) - -- if (free = var_1) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -6322,9 +6321,9 @@ relation fun_clos_deftypes: `%%`(deftype*, deftype*) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec:62.6-62.20 rule fun_clos_deftypes_case_1{`dt*` : deftype*, dt_n : deftype, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: `%%`(dt#2*{dt#2 <- `dt*`} ++ [dt_n], dt'*{dt' <- `dt'*`} ++ [var_0]) + -- if (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) - -- if (dt'#1*{dt'#1 <- `dt'*`} = var_1) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -6332,45 +6331,45 @@ 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, `dt*` : deftype*, var_1 : deftype*, var_0 : valtype}: `%%%`(C, t, var_0) + -- if (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) - -- if (dt#4*{dt#4 <- `dt*`} = var_1) ;; ../../../../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, `dt'*` : deftype*, var_1 : deftype*, var_0 : deftype}: `%%%`(C, dt, var_0) + -- if (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) - -- if (dt'#2*{dt'#2 <- `dt'*`} = var_1) ;; ../../../../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 rule fun_clos_tagtype_case_0{C : context, jt : typeuse, `dt*` : deftype*, var_1 : deftype*, var_0 : tagtype}: `%%%`(C, jt, var_0) + -- if (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) - -- if (dt#5*{dt#5 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rule fun_clos_externtype_case_0{C : context, xt : externtype, `dt*` : deftype*, var_1 : deftype*, var_0 : externtype}: `%%%`(C, xt, var_0) + -- if (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) - -- if (dt#6*{dt#6 <- `dt*`} = var_1) ;; ../../../../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, `dt*` : deftype*, var_1 : deftype*, var_0 : moduletype}: `%%%`(C, mmt, var_0) + -- if (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) - -- if (dt#7*{dt#7 <- `dt*`} = var_1) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -7361,13 +7360,11 @@ relation fun_default__before_fun_default__case_7: `%`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_3{var_0 : fN}: `%`(F64_valtype) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_2{var_0 : fN}: `%`(F32_valtype) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -7395,14 +7392,14 @@ relation fun_default_: `%%`(valtype, val??) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_2{var_0 : fN}: `%%`(F32_valtype, ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))))) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_3{var_0 : fN}: `%%`(F64_valtype, ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))))) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_4: @@ -9039,8 +9036,8 @@ relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec 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) -- 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*`}))) + -- 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) @@ -9282,14 +9279,14 @@ relation fun_zero: `%%`(lanetype, lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_zero_case_4{var_0 : fN}: `%%`(F32_lanetype, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_zero_case_5{var_0 : fN}: `%%`(F64_lanetype, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(bool : bool) : nat @@ -9345,9 +9342,9 @@ relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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)) + -- wf_uN: `%%`(N, `%`_uN(var_0)) -- fun_signed_: `%%%`(M, ($proj_uN_0(i).0 \ (2 ^ M)), var_1) -- fun_inv_signed_: `%%%`(N, var_1, var_0) - -- wf_uN: `%%`(N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(N : N, iN : iN, iN : iN) : iN @@ -9385,17 +9382,17 @@ relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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) - -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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))) + -- wf_uN: `%%`(N, `%`_uN(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) - -- wf_uN: `%%`(N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) @@ -9415,11 +9412,11 @@ relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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))) + -- wf_uN: `%%`(N, `%`_uN(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) - -- wf_uN: `%%`(N, `%`_uN(var_0)) - -- if ((j_1 = var_1) /\ (j_2 = var_2)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $imin_(N : N, sx : sx, iN : iN, iN : iN) : iN @@ -9855,14 +9852,14 @@ relation fun_unop_: `%%%%`(numtype, unop_, num_, num_*) ;; ../../../../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) -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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) -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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}: @@ -9969,26 +9966,26 @@ relation fun_binop_: `%%%%%`(numtype, binop_, num_, num_, num_*) ;; ../../../../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#30)*{iter_0#30 <- lift(var_0)}) - -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- 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#32)*{iter_0#32 <- lift(var_0)}) - -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- 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#34)*{iter_0#34 <- lift(var_0)}) - -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- 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 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#36)*{iter_0#36 <- lift(var_0)}) - -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- 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}: @@ -12449,10 +12446,6 @@ 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, `c_1*` : lane_*, `c**` : lane_**, `var_2*` : lane_**, var_1 : zero?, var_0 : half?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, v_1, v) - -- if (|`var_2*`| = |`c_1*`|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M))), c_1#169))*{c_1#169 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#303))*{c#303 <- `c*#43`}*{`c*#43` <- `c**`} @@ -12463,13 +12456,14 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c#304*{c#304 <- `c*#44`}*{`c*#44` <- `c**`} = $setproduct_(syntax lane_, var_2*{var_2 <- `var_2*`})) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M)), c#305*{c#305 <- `c*#45`})*{`c*#45` <- `c**`}) + -- if (|`var_2*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M)), `%X%`_shape(Lnn_2, `%`_dim(M)), vcvtop, c_1#171, var_2))*{var_2 <- `var_2*`, c_1#171 <- `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, `c_1*` : lane_*, `c**` : lane_**, `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_1*`| = |`c_1*`|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `c_1*`} - -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#172))*{c_1#172 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#306))*{c#306 <- `c*#46`}*{`c*#46` <- `c**`} @@ -12480,14 +12474,13 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c#307*{c#307 <- `c*#47`}*{`c*#47` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`})) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#308*{c#308 <- `c*#48`})*{`c*#48` <- `c**`}) + -- if (|`var_1*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- `var_1*`, c_1#174 <- `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, `c_1*` : lane_*, `c**` : lane_**, var_2 : lane_, `var_1*` : lane_**, var_0 : zero?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) - -- fun_zero: `%%`(Lnn_2, var_2) - -- if (|`var_1*`| = |`c_1*`|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `c_1*`} - -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#175))*{c_1#175 <- `c_1*`} -- (wf_lane_: `%%`(Lnn_2, c#309))*{c#309 <- `c*#49`}*{`c*#49` <- `c**`} @@ -12498,6 +12491,10 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c#310*{c#310 <- `c*#50`}*{`c*#50` <- `c**`} = $setproduct_(syntax lane_, var_1*{var_1 <- `var_1*`} ++ [var_2]^M_1{})) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c#311*{c#311 <- `c*#51`})*{`c*#51` <- `c**`}) + -- fun_zero: `%%`(Lnn_2, var_2) + -- if (|`var_1*`| = |`c_1*`|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- `var_1*`, c_1#177 <- `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_) @@ -12546,26 +12543,26 @@ 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(M))) + -- 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) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(M))) + -- 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_) @@ -12584,8 +12581,8 @@ 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#129110*{i#129110 <- `i*`}, v_1, v_2, var_0) - -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(M)), i*{i <- `i*`}, v_1, v_2, var_0) -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(M))) + -- 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_) @@ -13785,9 +13782,6 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v ;; ../../../../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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13804,13 +13798,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13827,13 +13821,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13850,13 +13844,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13873,13 +13867,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13896,13 +13890,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13919,13 +13913,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13942,13 +13936,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13965,13 +13959,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13988,13 +13982,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14011,13 +14005,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14034,13 +14028,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14057,13 +14051,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14080,13 +14074,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14103,13 +14097,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14126,13 +14120,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, 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) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14149,6 +14143,9 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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 = @@ -18510,14 +18507,14 @@ relation fun_alloctypes: `%%`(type*, deftype*) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:7.6-7.17 rule fun_alloctypes_case_1{`type'*` : type*, type : type, `deftype'*` : deftype*, `deftype*` : deftype*, rectype : rectype, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: `%%`(type'#1*{type'#1 <- `type'*`} ++ [type], deftype'*{deftype' <- `deftype'*`} ++ deftype*{deftype <- `deftype*`}) - -- 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) -- wf_uN: `%%`(32, x) -- if (deftype'#1*{deftype'#1 <- `deftype'*`} = var_0) -- if (type = TYPE_type(rectype)) -- if (deftype#1*{deftype#1 <- `deftype*`} = var_1) -- if ($proj_uN_0(x).0 = |deftype'#3*{deftype'#3 <- `deftype'*`}|) + -- 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 @@ -18541,12 +18538,12 @@ relation fun_alloctags: `%%%`(store, tagtype*, (store, tagaddr*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:20.6-20.16 rule fun_alloctags_case_1{s : store, tagtype : typeuse, `tagtype'*` : tagtype*, s_2 : store, ja : nat, `ja'*` : tagaddr*, s_1 : store, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: `%%%`(s, [tagtype] ++ tagtype'#1*{tagtype'#1 <- `tagtype'*`}, (s_2, [ja] ++ ja'*{ja' <- `ja'*`})) - -- fun_alloctags: `%%%`(s_1, tagtype'#2*{tagtype'#2 <- `tagtype'*`}, var_1) - -- fun_alloctag: `%%%`(s, tagtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ja) = var_0) -- if ((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 @@ -18570,12 +18567,12 @@ 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_1{s : store, globaltype : globaltype, `globaltype'*` : globaltype*, val : val, `val'*` : val*, s_2 : store, ga : nat, `ga'*` : globaladdr*, s_1 : store, 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'*`})) - -- fun_allocglobals: `%%%%`(s_1, globaltype'#2*{globaltype'#2 <- `globaltype'*`}, val'#2*{val'#2 <- `val'*`}, var_1) - -- fun_allocglobal: `%%%%`(s, globaltype, val, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ga) = var_0) -- if ((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 @@ -18599,12 +18596,12 @@ relation fun_allocmems: `%%%`(store, memtype*, (store, memaddr*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:42.6-42.16 rule fun_allocmems_case_1{s : store, memtype : memtype, `memtype'*` : memtype*, s_2 : store, ma : nat, `ma'*` : memaddr*, s_1 : store, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: `%%%`(s, [memtype] ++ memtype'#1*{memtype'#1 <- `memtype'*`}, (s_2, [ma] ++ ma'*{ma' <- `ma'*`})) - -- fun_allocmems: `%%%`(s_1, memtype'#2*{memtype'#2 <- `memtype'*`}, var_1) - -- fun_allocmem: `%%%`(s, memtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ma) = var_0) -- if ((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 @@ -18628,12 +18625,12 @@ 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_1{s : store, tabletype : tabletype, `tabletype'*` : tabletype*, ref : ref, `ref'*` : ref*, s_2 : store, ta : nat, `ta'*` : tableaddr*, s_1 : store, 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'*`})) - -- fun_alloctables: `%%%%`(s_1, tabletype'#2*{tabletype'#2 <- `tabletype'*`}, ref'#2*{ref'#2 <- `ref'*`}, var_1) - -- fun_alloctable: `%%%%`(s, tabletype, ref, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ta) = var_0) -- if ((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 @@ -18657,12 +18654,12 @@ relation fun_allocfuncs: `%%%%%`(store, deftype*, funccode*, moduleinst*, (store ;; ../../../../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*, s_2 : store, fa : nat, `fa'*` : funcaddr*, s_1 : store, 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'*`})) - -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, fa) = var_0) -- if ((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 @@ -18686,12 +18683,12 @@ 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_1{s : store, ok : datatype, `ok'*` : datatype*, `b*` : byte*, `b'**` : byte**, s_2 : store, da : nat, `da'*` : dataaddr*, s_1 : store, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: `%%%%`(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'*`})) - -- 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#11*{b#11 <- `b*`}, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, da) = var_0) -- if ((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#11*{b#11 <- `b*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -18715,12 +18712,12 @@ 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_1{s : store, rt : reftype, `rt'*` : reftype*, `ref*` : ref*, `ref'**` : ref**, s_2 : store, ea : nat, `ea'*` : elemaddr*, s_1 : store, 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'*`})) - -- 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) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ea) = var_0) -- if ((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 @@ -18768,31 +18765,6 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec 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, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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**, `aa_I*` : tagaddr*, `ga_I*` : globaladdr*, `ma_I*` : memaddr*, `ta_I*` : tableaddr*, `fa_I*` : funcaddr*, `dt*` : deftype*, `fa*` : nat*, s_1 : store, `aa*` : tagaddr*, s_2 : store, `ga*` : globaladdr*, s_3 : store, `ma*` : memaddr*, s_4 : store, `ta*` : tableaddr*, s_5 : store, `da*` : dataaddr*, s_6 : store, `ea*` : elemaddr*, `xi*` : exportinst*, var_18 : 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)) - -- fun_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) - -- (if ($proj_uN_0(x#4).0 < |dt#15*{dt#15 <- `dt*`}|))*{x#4 <- `x*`} - -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) - -- if (|`var_16*`| = |`elemtype*`|) - -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) - -- if (|`var_13*`| = |`tabletype*`|) - -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `tabletype*`} - -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) - -- if (|`var_11*`| = |`memtype*`|) - -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} - -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) - -- if (|`var_9*`| = |`globaltype*`|) - -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `globaltype*`} - -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) - -- if (|`var_7*`| = |`tagtype*`|) - -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} - -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) - -- fun_alloctypes: `%%`(type#4*{type#4 <- `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) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(moduleinst) -- wf_store: `%`(s_1) @@ -18842,6 +18814,31 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* -- if ((s_7, fa#4*{fa#4 <- `fa*`}) = var_17) -- if (xi#2*{xi#2 <- `xi*`} = var_18) -- if (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_allocexports: `%%%`({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 []}, export#7*{export#7 <- `export*`}, var_18) + -- (if ($proj_uN_0(x#4).0 < |dt#15*{dt#15 <- `dt*`}|))*{x#4 <- `x*`} + -- fun_allocfuncs: `%%%%%`(s_6, dt#15*{dt#15 <- `dt*`}[$proj_uN_0(x#4).0]*{x#4 <- `x*`}, FUNC_funccode(x#5, local#4*{local#4 <- `local*#86`}, expr_F#3)*{expr_F#3 <- `expr_F*`, `local*#86` <- `local**`, x#5 <- `x*`}, moduleinst^|func#7*{func#7 <- `func*`}|{}, var_17) + -- if (|`var_16*`| = |`elemtype*`|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- `dt*`}, var_16))*{var_16 <- `var_16*`, elemtype#3 <- `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#5*{data#5 <- `data*`}|{}, byte#7*{byte#7 <- `byte*#114`}*{`byte*#114` <- `byte**`}, var_14) + -- if (|`var_13*`| = |`tabletype*`|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- `dt*`}, var_13))*{var_13 <- `var_13*`, tabletype#160 <- `tabletype*`} + -- fun_alloctables: `%%%%`(s_3, var_13*{var_13 <- `var_13*`}, ref_T#2*{ref_T#2 <- `ref_T*`}, var_12) + -- if (|`var_11*`| = |`memtype*`|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- `dt*`}, var_11))*{var_11 <- `var_11*`, memtype#126 <- `memtype*`} + -- fun_allocmems: `%%%`(s_2, var_11*{var_11 <- `var_11*`}, var_10) + -- if (|`var_9*`| = |`globaltype*`|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- `dt*`}, var_9))*{var_9 <- `var_9*`, globaltype#126 <- `globaltype*`} + -- fun_allocglobals: `%%%%`(s_1, var_9*{var_9 <- `var_9*`}, val_G#2*{val_G#2 <- `val_G*`}, var_8) + -- if (|`var_7*`| = |`tagtype*`|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- `dt*`}, var_7))*{var_7 <- `var_7*`, tagtype#82 <- `tagtype*`} + -- fun_alloctags: `%%%`(s, var_7*{var_7 <- `var_7*`}, var_6) + -- fun_alloctypes: `%%`(type#4*{type#4 <- `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 fun_rundata_: `%%%`(dataidx, data, instr*) @@ -18888,13 +18885,13 @@ relation fun_evalexprs: `%%%`(state, expr*, (state, ref*)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:160.6-160.16 rule fun_evalexprs_case_1{z : state, expr : instr*, `expr'*` : expr*, z'' : state, ref : ref, `ref'*` : ref*, z' : state, var_0 : (state, ref*)}: `%%%`(z, [expr] ++ expr'#1*{expr'#1 <- `expr'*`}, (z'', [ref] ++ ref'*{ref' <- `ref'*`})) - -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) -- wf_state: `%`(z'') -- wf_ref: `%`(ref) -- (wf_ref: `%`(ref'#5))*{ref'#5 <- `ref'*`} -- wf_state: `%`(z') -- Eval_expr: `%;%~>*%;%`(z, expr, z', [$val_ref(ref)]) -- if ((z'', ref'#6*{ref'#6 <- `ref'*`}) = var_0) + -- fun_evalexprs: `%%%`(z', expr'#2*{expr'#2 <- `expr'*`}, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -18909,14 +18906,14 @@ relation fun_evalexprss: `%%%`(state, expr**, (state, ref**)) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec:167.6-167.17 rule fun_evalexprss_case_1{z : state, `expr*` : expr*, `expr'**` : expr**, z'' : state, `ref*` : ref*, `ref'**` : ref**, z' : state, 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'**`})) - -- fun_evalexprss: `%%%`(z', expr'#4*{expr'#4 <- `expr'*#2`}*{`expr'*#2` <- `expr'**`}, var_1) - -- fun_evalexprs: `%%%`(z, expr#366*{expr#366 <- `expr*`}, var_0) -- wf_state: `%`(z'') -- (wf_ref: `%`(ref#6))*{ref#6 <- `ref*`} -- (wf_ref: `%`(ref'#7))*{ref'#7 <- `ref'*#3`}*{`ref'*#3` <- `ref'**`} -- wf_state: `%`(z') -- if ((z', ref#7*{ref#7 <- `ref*`}) = var_0) -- if ((z'', ref'#8*{ref'#8 <- `ref'*#4`}*{`ref'*#4` <- `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 @@ -18931,8 +18928,6 @@ 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_1{z : state, gt : globaltype, `gt'*` : globaltype*, expr : instr*, `expr'*` : expr*, z'' : state, val : val, `val'*` : val*, z' : state, s : store, f : frame, s' : store, a : nat, 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'*`})) - -- 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) -- wf_state: `%`(z'') -- wf_val: `%`(val) -- (wf_val: `%`(val'#3))*{val'#3 <- `val'*`} @@ -18943,6 +18938,8 @@ relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) -- if (z' = `%;%`_state(s, f)) -- if ((s', a) = var_0) -- if ((z'', val'#4*{val'#4 <- `val'*`}) = var_1) + -- 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 @@ -18950,20 +18947,6 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rule fun_instantiate_case_0{s : store, module : module, `externaddr*` : externaddr*, s'''' : store, moduleinst : moduleinst, `instr_E*` : instr*, `instr_D*` : instr*, `instr_S?` : instr?, `xt_I*` : externtype*, `xt_E*` : externtype*, `type*` : type*, `import*` : import*, `tag*` : tag*, `global*` : global*, `mem*` : mem*, `table*` : table*, `func*` : func*, `data*` : data*, `elem*` : elem*, `start?` : start?, `export*` : export*, `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, z' : state, `val_G*` : val*, z'' : state, `ref_T*` : ref*, z''' : state, `ref_E**` : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, `var_11*` : instr**, `var_10*` : instr**, var_9 : (store, moduleinst), var_8 : (state, ref**), var_7 : (state, ref*), var_6 : (state, val*), var_5 : funcaddr*, var_4 : globaladdr*, var_3 : deftype*, 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?`}))) - -- (if (i_E#2 < |elem#12*{elem#12 <- `elem*`}|))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} - -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} - -- (if (i_D#2 < |data#11*{data#11 <- `data*`}|))^(i_D#2<|data#10*{data#10 <- `data*`}|){} - -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} - -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) - -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) - -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) - -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) - -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) - -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) - -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) - -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) - -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) - -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') -- (wf_val: `%`(val_G#3))*{val_G#3 <- `val_G*`} @@ -19009,6 +18992,20 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (instr_D#2*{instr_D#2 <- `instr_D*`} = $concat_(syntax instr, var_10^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`})) -- if (instr_E#2*{instr_E#2 <- `instr_E*`} = $concat_(syntax instr, var_11^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`})) -- if (instr_S#2?{instr_S#2 <- `instr_S?`} = CALL_instr(x#9)?{x#9 <- `x?`}) + -- (if (i_E#2 < |elem#12*{elem#12 <- `elem*`}|))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem#12*{elem#12 <- `elem*`}[i_E#2], var_11))^(i_E#2<|elem#11*{elem#11 <- `elem*`}|){var_11 <- `var_11*`} + -- (if (i_D#2 < |data#11*{data#11 <- `data*`}|))^(i_D#2<|data#10*{data#10 <- `data*`}|){} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data#11*{data#11 <- `data*`}[i_D#2], var_10))^(i_D#2<|data#10*{data#10 <- `data*`}|){var_10 <- `var_10*`} + -- fun_allocmodule: `%%%%%%%`(s''', module, externaddr#13*{externaddr#13 <- `externaddr*`}, val_G#5*{val_G#5 <- `val_G*`}, ref_T#5*{ref_T#5 <- `ref_T*`}, ref_E#5*{ref_E#5 <- `ref_E*#5`}*{`ref_E*#5` <- `ref_E**`}, var_9) + -- fun_evalexprss: `%%%`(z'', expr_E#5*{expr_E#5 <- `expr_E*#5`}*{`expr_E*#5` <- `expr_E**`}, var_8) + -- fun_evalexprs: `%%%`(z', expr_T#5*{expr_T#5 <- `expr_T*`}, var_7) + -- fun_evalglobals: `%%%%`(z, globaltype#131*{globaltype#131 <- `globaltype*`}, expr_G#5*{expr_G#5 <- `expr_G*`}, var_6) + -- fun_funcsxa: `%%`(externaddr#12*{externaddr#12 <- `externaddr*`}, var_5) + -- fun_globalsxa: `%%`(externaddr#11*{externaddr#11 <- `externaddr*`}, var_4) + -- fun_alloctypes: `%%`(type#8*{type#8 <- `type*`}, var_3) + -- fun_funcsxa: `%%`(externaddr#9*{externaddr#9 <- `externaddr*`}, var_2) + -- fun_globalsxa: `%%`(externaddr#8*{externaddr#8 <- `externaddr*`}, var_1) + -- fun_alloctypes: `%%`(type#6*{type#6 <- `type*`}, var_0) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec relation fun_invoke: `%%%%`(store, funcaddr, val*, config) @@ -19454,8 +19451,8 @@ relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rule fun_ordered_case_0{`decl*` : decl*, var_0 : import*}: `%%`(decl#1*{decl#1 <- `decl*`}, true) - -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) -- if (var_0 = []) + -- fun_importsd: `%%`(decl#2*{decl#2 <- `decl*`}, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec 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*}: diff --git a/spectec/test-middlend/specification.exp/12-improve-ids.il b/spectec/test-middlend/specification.exp/12-improve-ids.il index a73494eee4..6bac0e6138 100644 --- a/spectec/test-middlend/specification.exp/12-improve-ids.il +++ b/spectec/test-middlend/specification.exp/12-improve-ids.il @@ -420,35 +420,35 @@ relation fun_utf8: `%%`(char*, byte*) ;; ../../../../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]) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(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]) - -- fun_cont: `%%`(b_3, var_1) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(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]) - -- fun_cont: `%%`(b_4, var_2) - -- fun_cont: `%%`(b_3, var_1) - -- fun_cont: `%%`(b_2, var_0) -- wf_byte: `%`(b_1) -- wf_byte: `%`(b_2) -- wf_byte: `%`(b_3) -- wf_byte: `%`(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 @@ -1936,28 +1936,27 @@ relation fun_subst_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.6-401.17 relation fun_minus_recs_before_fun_minus_recs_case_3: `%%`(typevar*, typeuse*) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_2{x : uN, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*, tv'_lst : typevar*, tu'_lst : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%`([_IDX_typevar(x)] ++ tv_lst, [tu_1] ++ tu_lst) - -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- tv'_lst} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- tu'_lst} -- wf_typevar: `%`(_IDX_typevar(x)) -- if (var_0 =/= ?()) -- if ((tv'_lst, tu'_lst) = !(var_0)) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_1{v_n : nat, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%`([REC_typevar(v_n)] ++ tv_lst, [tu_1] ++ tu_lst) - ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_minus_recs_case_0: `%%`([], []) +;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec +rec { + ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 @@ -1972,12 +1971,12 @@ relation fun_minus_recs: `%%%`(typevar*, typeuse*, (typevar*, typeuse*)?) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 rule fun_minus_recs_case_2{x : uN, tv_lst : typevar*, tu_1 : typeuse, tu_lst : typeuse*, tv'_lst : typevar*, tu'_lst : typeuse*, var_0 : (typevar*, typeuse*)?}: `%%%`([_IDX_typevar(x)] ++ tv_lst, [tu_1] ++ tu_lst, ?(([_IDX_typevar(x)] ++ tv'_lst, [tu_1] ++ tu'_lst))) - -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_0) -- (wf_typevar: `%`(tv'#2))*{tv'#2 <- tv'_lst} -- (wf_typeuse: `%`(tu'#2))*{tu'#2 <- tu'_lst} -- wf_typevar: `%`(_IDX_typevar(x)) -- if (var_0 =/= ?()) -- if ((tv'_lst, tu'_lst) = !(var_0)) + -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_0) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:401.6-401.17 rule fun_minus_recs_case_3{x0 : typevar*, x1 : typeuse*}: @@ -2050,9 +2049,9 @@ 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_1 : heaptype, var_0 : heaptype}: `%%%%`(REF_reftype(null_opt, ht), tv_lst, tu_lst, REF_reftype(null_opt, var_0)) + -- wf_reftype: `%`(REF_reftype(null_opt, var_1)) -- fun_subst_heaptype: `%%%%`(ht, tv_lst, tu_lst, var_1) -- fun_subst_heaptype: `%%%%`(ht, tv_lst, tu_lst, var_0) - -- wf_reftype: `%`(REF_reftype(null_opt, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:345.6-345.20 relation fun_subst_valtype: `%%%%`(valtype, typevar*, typeuse*, valtype) @@ -2136,31 +2135,32 @@ 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_1 : storagetype, var_0 : storagetype}: `%%%%`(`%%`_fieldtype(mut_opt, zt), tv_lst, tu_lst, `%%`_fieldtype(mut_opt, var_0)) + -- wf_fieldtype: `%`(`%%`_fieldtype(mut_opt, var_1)) -- fun_subst_storagetype: `%%%%`(zt, tv_lst, tu_lst, var_1) -- fun_subst_storagetype: `%%%%`(zt, tv_lst, tu_lst, var_0) - -- wf_fieldtype: `%`(`%%`_fieldtype(mut_opt, var_1)) ;; ../../../../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_1_lst : fieldtype*, var_0_lst : fieldtype*}: `%%%%`(STRUCT_comptype(`%`_list(ft_lst)), tv_lst, tu_lst, STRUCT_comptype(`%`_list(var_0_lst))) + -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1_lst))) -- if (|var_1_lst| = |ft_lst|) -- (fun_subst_fieldtype: `%%%%`(ft#2, tv_lst, tu_lst, var_1))*{var_1 <- var_1_lst, ft#2 <- ft_lst} -- if (|var_0_lst| = |ft_lst|) -- (fun_subst_fieldtype: `%%%%`(ft, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, ft <- ft_lst} - -- wf_comptype: `%`(STRUCT_comptype(`%`_list(var_1_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_1 : fieldtype, var_0 : fieldtype}: `%%%%`(ARRAY_comptype(ft), tv_lst, tu_lst, ARRAY_comptype(var_0)) + -- wf_comptype: `%`(ARRAY_comptype(var_1)) -- fun_subst_fieldtype: `%%%%`(ft, tv_lst, tu_lst, var_1) -- fun_subst_fieldtype: `%%%%`(ft, tv_lst, tu_lst, var_0) - -- wf_comptype: `%`(ARRAY_comptype(var_1)) ;; ../../../../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_3_lst : valtype*, var_2_lst : valtype*, var_1_lst : valtype*, var_0_lst : valtype*}: `%%%%`(`FUNC%->%`_comptype(`%`_resulttype(t_1_lst), `%`_resulttype(t_2_lst)), tv_lst, tu_lst, `FUNC%->%`_comptype(`%`_resulttype(var_0_lst), `%`_resulttype(var_1_lst))) + -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2_lst), `%`_resulttype(var_3_lst))) -- if (|var_3_lst| = |t_2_lst|) -- (fun_subst_valtype: `%%%%`(t_2#2, tv_lst, tu_lst, var_3))*{var_3 <- var_3_lst, t_2#2 <- t_2_lst} -- if (|var_2_lst| = |t_1_lst|) @@ -2169,33 +2169,32 @@ relation fun_subst_comptype: `%%%%`(comptype, typevar*, typeuse*, comptype) -- (fun_subst_valtype: `%%%%`(t_2, tv_lst, tu_lst, var_1))*{var_1 <- var_1_lst, t_2 <- t_2_lst} -- if (|var_0_lst| = |t_1_lst|) -- (fun_subst_valtype: `%%%%`(t_1, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, t_1 <- t_1_lst} - -- wf_comptype: `%`(`FUNC%->%`_comptype(`%`_resulttype(var_2_lst), `%`_resulttype(var_3_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_3 : comptype, var_2_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)) + -- wf_subtype: `%`(SUB_subtype(final_opt, var_2_lst, var_3)) -- fun_subst_comptype: `%%%%`(ct, tv_lst, tu_lst, var_3) -- if (|var_2_lst| = |tu'_lst|) -- (fun_subst_typeuse: `%%%%`(tu'#5, tv_lst, tu_lst, var_2))*{var_2 <- var_2_lst, tu'#5 <- tu'_lst} -- fun_subst_comptype: `%%%%`(ct, tv_lst, tu_lst, var_1) -- if (|var_0_lst| = |tu'_lst|) -- (fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, tu' <- tu'_lst} - -- wf_subtype: `%`(SUB_subtype(final_opt, var_2_lst, var_3)) ;; ../../../../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*, tv'_lst : typevar*, tu'_lst : typeuse*, var_1 : (typevar*, typeuse*)?, var_0_lst : subtype*}: `%%%%`(REC_rectype(`%`_list(st_lst)), tv_lst, tu_lst, REC_rectype(`%`_list(var_0_lst))) - -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_1) - -- if (|var_0_lst| = |st_lst|) - -- (fun_subst_subtype: `%%%%`(st, tv'_lst, tu'_lst, var_0))*{var_0 <- var_0_lst, st <- st_lst} -- (wf_typevar: `%`(tv'#4))*{tv'#4 <- tv'_lst} -- (wf_typeuse: `%`(tu'#6))*{tu'#6 <- tu'_lst} -- if (var_1 =/= ?()) -- if ((tv'_lst, tu'_lst) = !(var_1)) + -- fun_minus_recs: `%%%`(tv_lst, tu_lst, var_1) + -- if (|var_0_lst| = |st_lst|) + -- (fun_subst_subtype: `%%%%`(st, tv'_lst, tu'_lst, var_0))*{var_0 <- var_0_lst, st <- st_lst} ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec:354.6-354.20 relation fun_subst_deftype: `%%%%`(deftype, typevar*, typeuse*, deftype) @@ -2222,9 +2221,9 @@ relation fun_subst_globaltype: `%%%%`(globaltype, typevar*, typeuse*, globaltype ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_globaltype_case_0{mut_opt : mut?, t : valtype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : valtype, var_0 : valtype}: `%%%%`(`%%`_globaltype(mut_opt, t), tv_lst, tu_lst, `%%`_globaltype(mut_opt, var_0)) + -- wf_globaltype: `%`(`%%`_globaltype(mut_opt, var_1)) -- fun_subst_valtype: `%%%%`(t, tv_lst, tu_lst, var_1) -- fun_subst_valtype: `%%%%`(t, tv_lst, tu_lst, var_0) - -- wf_globaltype: `%`(`%%`_globaltype(mut_opt, var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec relation fun_subst_memtype: `%%%%`(memtype, typevar*, typeuse*, memtype) @@ -2238,52 +2237,53 @@ 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_1 : reftype, var_0 : reftype}: `%%%%`(`%%%`_tabletype(at, lim, rt), tv_lst, tu_lst, `%%%`_tabletype(at, lim, var_0)) + -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) -- fun_subst_reftype: `%%%%`(rt, tv_lst, tu_lst, var_1) -- fun_subst_reftype: `%%%%`(rt, tv_lst, tu_lst, var_0) - -- wf_tabletype: `%`(`%%%`_tabletype(at, lim, var_1)) ;; ../../../../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_lst : typevar*, tu_lst : typeuse*, var_1 : tagtype, var_0 : tagtype}: `%%%%`(TAG_externtype(jt), tv_lst, tu_lst, TAG_externtype(var_0)) + -- wf_externtype: `%`(TAG_externtype(var_1)) -- fun_subst_tagtype: `%%%%`(jt, tv_lst, tu_lst, var_1) -- fun_subst_tagtype: `%%%%`(jt, tv_lst, tu_lst, var_0) - -- wf_externtype: `%`(TAG_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_1{gt : globaltype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : globaltype, var_0 : globaltype}: `%%%%`(GLOBAL_externtype(gt), tv_lst, tu_lst, GLOBAL_externtype(var_0)) + -- wf_externtype: `%`(GLOBAL_externtype(var_1)) -- fun_subst_globaltype: `%%%%`(gt, tv_lst, tu_lst, var_1) -- fun_subst_globaltype: `%%%%`(gt, tv_lst, tu_lst, var_0) - -- wf_externtype: `%`(GLOBAL_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_2{tt : tabletype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : tabletype, var_0 : tabletype}: `%%%%`(TABLE_externtype(tt), tv_lst, tu_lst, TABLE_externtype(var_0)) + -- wf_externtype: `%`(TABLE_externtype(var_1)) -- fun_subst_tabletype: `%%%%`(tt, tv_lst, tu_lst, var_1) -- fun_subst_tabletype: `%%%%`(tt, tv_lst, tu_lst, var_0) - -- wf_externtype: `%`(TABLE_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_3{mt : memtype, tv_lst : typevar*, tu_lst : typeuse*, var_1 : memtype, var_0 : memtype}: `%%%%`(MEM_externtype(mt), tv_lst, tu_lst, MEM_externtype(var_0)) + -- wf_externtype: `%`(MEM_externtype(var_1)) -- fun_subst_memtype: `%%%%`(mt, tv_lst, tu_lst, var_1) -- fun_subst_memtype: `%%%%`(mt, tv_lst, tu_lst, var_0) - -- wf_externtype: `%`(MEM_externtype(var_1)) ;; ../../../../specification/wasm-3.0/1.2-syntax.types.spectec rule fun_subst_externtype_case_4{tu' : typeuse, tv_lst : typevar*, tu_lst : typeuse*, var_1 : typeuse, var_0 : typeuse}: `%%%%`(FUNC_externtype(tu'), tv_lst, tu_lst, FUNC_externtype(var_0)) + -- wf_externtype: `%`(FUNC_externtype(var_1)) -- fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_1) -- fun_subst_typeuse: `%%%%`(tu', tv_lst, tu_lst, var_0) - -- wf_externtype: `%`(FUNC_externtype(var_1)) ;; ../../../../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_3_lst : externtype*, var_2_lst : externtype*, var_1_lst : externtype*, var_0_lst : externtype*}: `%%%%`(`%->%`_moduletype(xt_1_lst, xt_2_lst), tv_lst, tu_lst, `%->%`_moduletype(var_0_lst, var_1_lst)) + -- wf_moduletype: `%`(`%->%`_moduletype(var_2_lst, var_3_lst)) -- if (|var_3_lst| = |xt_2_lst|) -- (fun_subst_externtype: `%%%%`(xt_2#2, tv_lst, tu_lst, var_3))*{var_3 <- var_3_lst, xt_2#2 <- xt_2_lst} -- if (|var_2_lst| = |xt_1_lst|) @@ -2292,79 +2292,78 @@ relation fun_subst_moduletype: `%%%%`(moduletype, typevar*, typeuse*, moduletype -- (fun_subst_externtype: `%%%%`(xt_2, tv_lst, tu_lst, var_1))*{var_1 <- var_1_lst, xt_2 <- xt_2_lst} -- if (|var_0_lst| = |xt_1_lst|) -- (fun_subst_externtype: `%%%%`(xt_1, tv_lst, tu_lst, var_0))*{var_0 <- var_0_lst, xt_1 <- xt_1_lst} - -- wf_moduletype: `%`(`%->%`_moduletype(var_2_lst, var_3_lst)) ;; ../../../../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) - -- fun_subst_valtype: `%%%%`(t, _IDX_typevar(`%`_typeidx(i))^(i int) - (1 : nat <:> int)) : int <:> nat))] ++ var_0) - -- fun_shift_labelidxs: `%%`(labelidx'_lst, var_0) -- wf_uN: `%%`(32, `%`_uN(((($proj_uN_0(v_labelidx).0 : nat <:> int) - (1 : nat <:> int)) : int <:> nat))) + -- fun_shift_labelidxs: `%%`(labelidx'_lst, var_0) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -5839,12 +5838,12 @@ 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*, v_free : free, var_2_lst : free*, var_1 : free, var_0 : labelidx*}: `%%`(instr_lst, v_free[LABELS_free = var_0]) + -- wf_free: `%`(v_free) + -- if (v_free = var_1) -- if (|var_2_lst| = |instr_lst|) -- (fun_free_instr: `%%`(instr#5, var_2))*{var_2 <- var_2_lst, instr#5 <- instr_lst} -- fun_free_list: `%%`(var_2_lst, var_1) -- fun_shift_labelidxs: `%%`(v_free.LABELS_free, var_0) - -- wf_free: `%`(v_free) - -- if (v_free = var_1) } ;; ../../../../specification/wasm-3.0/1.3-syntax.instructions.spectec @@ -6322,9 +6321,9 @@ relation fun_clos_deftypes: `%%`(deftype*, deftype*) ;; ../../../../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, dt'_lst : deftype*, var_1 : deftype*, var_0 : deftype}: `%%`(dt_lst ++ [dt_n], dt'_lst ++ [var_0]) + -- if (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) - -- if (dt'_lst = var_1) } ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec @@ -6332,45 +6331,45 @@ 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, dt_lst : deftype*, var_1 : deftype*, var_0 : valtype}: `%%%`(C, t, var_0) + -- if (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) - -- if (dt_lst = var_1) ;; ../../../../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, dt'_lst : deftype*, var_1 : deftype*, var_0 : deftype}: `%%%`(C, dt, var_0) + -- if (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) - -- if (dt'_lst = var_1) ;; ../../../../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 rule fun_clos_tagtype_case_0{C : context, jt : typeuse, dt_lst : deftype*, var_1 : deftype*, var_0 : tagtype}: `%%%`(C, jt, var_0) + -- if (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) - -- if (dt_lst = var_1) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec relation fun_clos_externtype: `%%%`(context, externtype, externtype) ;; ../../../../specification/wasm-3.0/2.0-validation.contexts.spectec rule fun_clos_externtype_case_0{C : context, xt : externtype, dt_lst : deftype*, var_1 : deftype*, var_0 : externtype}: `%%%`(C, xt, var_0) + -- if (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) - -- if (dt_lst = var_1) ;; ../../../../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, dt_lst : deftype*, var_1 : deftype*, var_0 : moduletype}: `%%%`(C, mmt, var_0) + -- if (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) - -- if (dt_lst = var_1) ;; ../../../../specification/wasm-3.0/2.1-validation.types.spectec relation Numtype_ok: `%|-%:OK`(context, numtype) @@ -7361,13 +7360,11 @@ relation fun_default__before_fun_default__case_7: `%`(valtype) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_3{var_0 : fN}: `%`(F64_valtype) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_2{var_0 : fN}: `%`(F32_valtype) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec @@ -7395,14 +7392,14 @@ relation fun_default_: `%%`(valtype, val??) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_2{var_0 : fN}: `%%`(F32_valtype, ?(?(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))))) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_3{var_0 : fN}: `%%`(F64_valtype, ?(?(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))))) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_val: `%`(CONST_val($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/4.1-execution.values.spectec rule fun_default__case_4: @@ -9039,8 +9036,8 @@ relation fun_funcidx_nonfuncs: `%%`(nonfuncs, funcidx*) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec 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*}: `%%`(`%%%%%%`_nonfuncs(global_lst, mem_lst, table_lst, elem_lst, start_opt, export_lst), var_0) - -- fun_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)), var_0) -- 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))) + -- fun_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)), var_0) ;; ../../../../specification/wasm-3.0/2.4-validation.modules.spectec relation Module_ok: `|-%:%`(module, moduletype) @@ -9282,14 +9279,14 @@ relation fun_zero: `%%`(lanetype, lane_) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_zero_case_4{var_0 : fN}: `%%`(F32_lanetype, mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) - -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) -- wf_lane_: `%%`($lanetype_Fnn(F32_Fnn), mk_lane__0_lane_($numtype_Fnn(F32_Fnn), mk_num__1_num_(F32_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F32_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_zero_case_5{var_0 : fN}: `%%`(F64_lanetype, mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) - -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) -- wf_lane_: `%%`($lanetype_Fnn(F64_Fnn), mk_lane__0_lane_($numtype_Fnn(F64_Fnn), mk_num__1_num_(F64_Fnn, var_0))) + -- fun_fzero: `%%`($size($numtype_Fnn(F64_Fnn)), var_0) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $bool(v_bool : bool) : nat @@ -9345,9 +9342,9 @@ relation fun_iextend_: `%%%%%`(N, M, sx, iN, iN) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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, `%`_iN(var_0)) + -- wf_uN: `%%`(v_N, `%`_uN(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) - -- wf_uN: `%%`(v_N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec def $iadd_(v_N : N, v_iN : iN, v_iN_0 : iN) : iN @@ -9385,17 +9382,17 @@ relation fun_idiv_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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) - -- if (((var_0 : int <:> rat) / (var_1 : int <:> rat)) = ((2 ^ (((v_N : nat <:> int) - (1 : nat <:> int)) : int <:> nat)) : nat <:> rat)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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, ?(`%`_iN(var_0))) + -- wf_uN: `%%`(v_N, `%`_uN(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) - -- wf_uN: `%%`(v_N, `%`_uN(var_0)) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) @@ -9415,11 +9412,11 @@ relation fun_irem_: `%%%%%`(N, sx, iN, iN, iN?) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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, ?(`%`_iN(var_0))) + -- wf_uN: `%%`(v_N, `%`_uN(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) - -- wf_uN: `%%`(v_N, `%`_uN(var_0)) - -- if ((j_1 = var_1) /\ (j_2 = var_2)) ;; ../../../../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 @@ -9855,14 +9852,14 @@ relation fun_unop_: `%%%%`(numtype, unop_, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec rule fun_unop__case_6{v_M : nat, i : uN, var_0 : 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, var_0)]) - -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_M, S_sx, i, var_0) -- wf_num_: `%%`($numtype_addrtype(I32_Inn), 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 rule fun_unop__case_7{v_M : nat, i : uN, var_0 : 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, var_0)]) - -- fun_iextend_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_M, S_sx, i, var_0) -- wf_num_: `%%`($numtype_addrtype(I64_Inn), 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 rule fun_unop__case_8{f : fN}: @@ -9969,26 +9966,26 @@ relation fun_binop_: `%%%%%`(numtype, binop_, num_, num_, num_*) ;; ../../../../specification/wasm-3.0/3.1-numerics.scalar.spectec 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#30)*{iter_0#30 <- lift(var_0)}) - -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#29)))*{iter_0#29 <- 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 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#32)*{iter_0#32 <- lift(var_0)}) - -- fun_idiv_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#31)))*{iter_0#31 <- 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 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#34)*{iter_0#34 <- lift(var_0)}) - -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I32_Inn)), v_sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I32_Inn), mk_num__0_num_(I32_Inn, iter_0#33)))*{iter_0#33 <- 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 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#36)*{iter_0#36 <- lift(var_0)}) - -- fun_irem_: `%%%%%`($sizenn($numtype_addrtype(I64_Inn)), v_sx, i_1, i_2, var_0) -- (wf_num_: `%%`($numtype_addrtype(I64_Inn), mk_num__0_num_(I64_Inn, iter_0#35)))*{iter_0#35 <- 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 rule fun_binop__case_10{i_1 : uN, i_2 : uN}: @@ -12449,10 +12446,6 @@ 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, c_1_lst : lane_*, c_lst_lst : lane_**, var_2_lst : lane_**, var_1 : zero?, var_0 : half?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, v_1, v) - -- if (|var_2_lst| = |c_1_lst|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, c_1#171, var_2))*{var_2 <- var_2_lst, c_1#171 <- c_1_lst} - -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, var_1) - -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape(Lnn_1, `%`_dim(v_M))), c_1#169))*{c_1#169 <- c_1_lst} -- (wf_lane_: `%%`(Lnn_2, c#303))*{c#303 <- c_lst#43}*{c_lst#43 <- c_lst_lst} @@ -12463,13 +12456,14 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c_lst_lst = $setproduct_(syntax lane_, var_2_lst)) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(v_M)), c_lst#45)*{c_lst#45 <- c_lst_lst}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(v_M)), c_lst#45)*{c_lst#45 <- c_lst_lst}) + -- if (|var_2_lst| = |c_1_lst|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, c_1#171, var_2))*{var_2 <- var_2_lst, c_1#171 <- c_1_lst} + -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_dim(v_M)), vcvtop, var_1) + -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(v_M)), `%X%`_shape(Lnn_2, `%`_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, c_1_lst : lane_*, c_lst_lst : lane_**, var_1_lst : lane_**, var_0 : half?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) - -- if (|var_1_lst| = |c_1_lst|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- var_1_lst, c_1#174 <- c_1_lst} - -- fun_halfop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#172))*{c_1#172 <- c_1_lst} -- (wf_lane_: `%%`(Lnn_2, c#306))*{c#306 <- c_lst#46}*{c_lst#46 <- c_lst_lst} @@ -12480,14 +12474,13 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c_lst_lst = $setproduct_(syntax lane_, var_1_lst)) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#48)*{c_lst#48 <- c_lst_lst}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#48)*{c_lst#48 <- c_lst_lst}) + -- if (|var_1_lst| = |c_1_lst|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#174, var_1))*{var_1 <- var_1_lst, c_1#174 <- c_1_lst} + -- 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, c_1_lst : lane_*, c_lst_lst : lane_**, var_2 : lane_, var_1_lst : lane_**, var_0 : zero?}: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, v_1, v) - -- fun_zero: `%%`(Lnn_2, var_2) - -- if (|var_1_lst| = |c_1_lst|) - -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- var_1_lst, c_1#177 <- c_1_lst} - -- fun_zeroop: `%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, var_0) -- wf_uN: `%%`(128, v) -- (wf_lane_: `%%`($fun_lanetype(`%X%`_shape(Lnn_1, `%`_dim(M_1))), c_1#175))*{c_1#175 <- c_1_lst} -- (wf_lane_: `%%`(Lnn_2, c#309))*{c#309 <- c_lst#49}*{c_lst#49 <- c_lst_lst} @@ -12498,6 +12491,10 @@ relation fun_vcvtop__: `%%%%%`(shape, shape, vcvtop__, vec_, vec_) -- if (c_lst_lst = $setproduct_(syntax lane_, var_1_lst ++ [var_2]^M_1{})) -- if (|$inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#51)*{c_lst#51 <- c_lst_lst}| > 0) -- if (v <- $inv_lanes_(`%X%`_shape(Lnn_2, `%`_dim(M_2)), c_lst#51)*{c_lst#51 <- c_lst_lst}) + -- fun_zero: `%%`(Lnn_2, var_2) + -- if (|var_1_lst| = |c_1_lst|) + -- (fun_lcvtop__: `%%%%%`(`%X%`_shape(Lnn_1, `%`_dim(M_1)), `%X%`_shape(Lnn_2, `%`_dim(M_2)), vcvtop, c_1#177, var_1))*{var_1 <- var_1_lst, c_1#177 <- c_1_lst} + -- 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_) @@ -12546,26 +12543,26 @@ relation fun_vbitmaskop_: `%%%`(ishape, vec_, u32) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec rule fun_vbitmaskop__case_0{v_M : nat, v : uN, var_0 : u32}: `%%%`(`%`_ishape(`%X%`_shape(I32_lanetype, `%`_dim(v_M))), v, var_0) - -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v, var_0) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M))) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I32_Jnn), `%`_dim(v_M)), v, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec rule fun_vbitmaskop__case_1{v_M : nat, v : uN, var_0 : u32}: `%%%`(`%`_ishape(`%X%`_shape(I64_lanetype, `%`_dim(v_M))), v, var_0) - -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v, var_0) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M))) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I64_Jnn), `%`_dim(v_M)), v, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec rule fun_vbitmaskop__case_2{v_M : nat, v : uN, var_0 : u32}: `%%%`(`%`_ishape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), v, var_0) - -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v, var_0) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M))) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I8_Jnn), `%`_dim(v_M)), v, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec rule fun_vbitmaskop__case_3{v_M : nat, v : uN, var_0 : u32}: `%%%`(`%`_ishape(`%X%`_shape(I16_lanetype, `%`_dim(v_M))), v, var_0) - -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v, var_0) -- wf_shape: `%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M))) + -- fun_ivbitmaskop_: `%%%`(`%X%`_shape($lanetype_Jnn(I16_Jnn), `%`_dim(v_M)), v, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec relation fun_vswizzlop_: `%%%%%`(bshape, vswizzlop_, vec_, vec_, vec_) @@ -12584,8 +12581,8 @@ relation fun_vshufflop_: `%%%%%`(bshape, laneidx*, vec_, vec_, vec_) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec rule fun_vshufflop__case_0{v_M : nat, i_lst : laneidx*, v_1 : uN, v_2 : uN, var_0 : vec_}: `%%%%%`(`%`_bshape(`%X%`_shape(I8_lanetype, `%`_dim(v_M))), i_lst, v_1, v_2, var_0) - -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), i_lst, v_1, v_2, var_0) -- wf_shape: `%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M))) + -- fun_ivshufflop_: `%%%%%`(`%X%`_shape(I8_lanetype, `%`_dim(v_M)), i_lst, v_1, v_2, var_0) ;; ../../../../specification/wasm-3.0/3.2-numerics.vector.spectec relation fun_vnarrowop__: `%%%%%%`(shape, shape, sx, vec_, vec_, vec_) @@ -13785,9 +13782,6 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v ;; ../../../../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, v_Jnn : Jnn, v_M : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13804,13 +13798,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13827,13 +13821,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13850,13 +13844,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I32_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13873,13 +13867,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13896,13 +13890,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13919,13 +13913,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13942,13 +13936,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I64_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13965,13 +13959,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -13988,13 +13982,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14011,13 +14005,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14034,13 +14028,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I8_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14057,13 +14051,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14080,13 +14074,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14103,13 +14097,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14126,13 +14120,13 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, 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, v_M : nat, c' : uN, c'' : uN, 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, I16_Jnn, M_2, RELAXED_DOT_ADDS_vextternop__Jnn_1_M_1_Jnn_2_M_2), c_1, c_2, c_3, 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, var_2) - -- 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', var_1) - -- 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, var_0) -- wf_uN: `%%`(128, c) -- wf_uN: `%%`(128, c') -- wf_uN: `%%`(128, c'') @@ -14149,6 +14143,9 @@ relation fun_vextternop__: `%%%%%%%`(ishape, ishape, vextternop__, vec_, vec_, v -- if (c'' = var_1) -- if (|var_2| > 0) -- if (c <- var_2) + -- 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(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', var_1) + -- 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, var_0) ;; ../../../../specification/wasm-3.0/4.0-execution.configurations.spectec syntax num = @@ -18510,14 +18507,14 @@ relation fun_alloctypes: `%%`(type*, deftype*) ;; ../../../../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*, deftype_lst : deftype*, v_rectype : rectype, x : uN, var_2 : deftype*, var_1 : deftype*, var_0 : deftype*}: `%%`(type'_lst ++ [v_type], deftype'_lst ++ deftype_lst) - -- 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) -- wf_uN: `%%`(32, x) -- if (deftype'_lst = var_0) -- if (v_type = TYPE_type(v_rectype)) -- if (deftype_lst = var_1) -- if ($proj_uN_0(x).0 = |deftype'_lst|) + -- 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 @@ -18541,12 +18538,12 @@ relation fun_alloctags: `%%%`(store, tagtype*, (store, tagaddr*)) ;; ../../../../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*, s_2 : store, ja : nat, ja'_lst : tagaddr*, s_1 : store, var_1 : (store, tagaddr*), var_0 : (store, tagaddr)}: `%%%`(s, [v_tagtype] ++ tagtype'_lst, (s_2, [ja] ++ ja'_lst)) - -- fun_alloctags: `%%%`(s_1, tagtype'_lst, var_1) - -- fun_alloctag: `%%%`(s, v_tagtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ja) = var_0) -- if ((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 @@ -18570,12 +18567,12 @@ 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_1{s : store, v_globaltype : globaltype, globaltype'_lst : globaltype*, v_val : val, val'_lst : val*, s_2 : store, ga : nat, ga'_lst : globaladdr*, s_1 : store, var_1 : (store, globaladdr*), var_0 : (store, globaladdr)}: `%%%%`(s, [v_globaltype] ++ globaltype'_lst, [v_val] ++ val'_lst, (s_2, [ga] ++ ga'_lst)) - -- fun_allocglobals: `%%%%`(s_1, globaltype'_lst, val'_lst, var_1) - -- fun_allocglobal: `%%%%`(s, v_globaltype, v_val, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ga) = var_0) -- if ((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 @@ -18599,12 +18596,12 @@ relation fun_allocmems: `%%%`(store, memtype*, (store, memaddr*)) ;; ../../../../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*, s_2 : store, ma : nat, ma'_lst : memaddr*, s_1 : store, var_1 : (store, memaddr*), var_0 : (store, memaddr)}: `%%%`(s, [v_memtype] ++ memtype'_lst, (s_2, [ma] ++ ma'_lst)) - -- fun_allocmems: `%%%`(s_1, memtype'_lst, var_1) - -- fun_allocmem: `%%%`(s, v_memtype, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ma) = var_0) -- if ((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 @@ -18628,12 +18625,12 @@ 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_1{s : store, v_tabletype : tabletype, tabletype'_lst : tabletype*, v_ref : ref, ref'_lst : ref*, s_2 : store, ta : nat, ta'_lst : tableaddr*, s_1 : store, var_1 : (store, tableaddr*), var_0 : (store, tableaddr)}: `%%%%`(s, [v_tabletype] ++ tabletype'_lst, [v_ref] ++ ref'_lst, (s_2, [ta] ++ ta'_lst)) - -- fun_alloctables: `%%%%`(s_1, tabletype'_lst, ref'_lst, var_1) - -- fun_alloctable: `%%%%`(s, v_tabletype, v_ref, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ta) = var_0) -- if ((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 @@ -18657,12 +18654,12 @@ relation fun_allocfuncs: `%%%%%`(store, deftype*, funccode*, moduleinst*, (store ;; ../../../../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*, s_2 : store, fa : nat, fa'_lst : funcaddr*, s_1 : store, 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)) - -- fun_allocfuncs: `%%%%%`(s_1, dt'_lst, funccode'_lst, moduleinst'_lst, var_1) - -- fun_allocfunc: `%%%%%`(s, dt, v_funccode, v_moduleinst, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, fa) = var_0) -- if ((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 @@ -18686,12 +18683,12 @@ 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_1{s : store, ok : datatype, ok'_lst : datatype*, b_lst : byte*, b'_lst_lst : byte**, s_2 : store, da : nat, da'_lst : dataaddr*, s_1 : store, var_1 : (store, dataaddr*), var_0 : (store, dataaddr)}: `%%%%`(s, [ok] ++ ok'_lst, [b_lst] ++ b'_lst_lst, (s_2, [da] ++ da'_lst)) - -- fun_allocdatas: `%%%%`(s_1, ok'_lst, b'_lst_lst, var_1) - -- fun_allocdata: `%%%%`(s, ok, b_lst, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, da) = var_0) -- if ((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 @@ -18715,12 +18712,12 @@ 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_1{s : store, rt : reftype, rt'_lst : reftype*, ref_lst : ref*, ref'_lst_lst : ref**, s_2 : store, ea : nat, ea'_lst : elemaddr*, s_1 : store, var_1 : (store, elemaddr*), var_0 : (store, elemaddr)}: `%%%%`(s, [rt] ++ rt'_lst, [ref_lst] ++ ref'_lst_lst, (s_2, [ea] ++ ea'_lst)) - -- fun_allocelems: `%%%%`(s_1, rt'_lst, ref'_lst_lst, var_1) - -- fun_allocelem: `%%%%`(s, rt, ref_lst, var_0) -- wf_store: `%`(s_2) -- wf_store: `%`(s_1) -- if ((s_1, ea) = var_0) -- if ((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 @@ -18768,31 +18765,6 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec 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, 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*, 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**, aa_I_lst : tagaddr*, ga_I_lst : globaladdr*, ma_I_lst : memaddr*, ta_I_lst : tableaddr*, fa_I_lst : funcaddr*, dt_lst : deftype*, fa_lst : nat*, s_1 : store, aa_lst : tagaddr*, s_2 : store, ga_lst : globaladdr*, s_3 : store, ma_lst : memaddr*, s_4 : store, ta_lst : tableaddr*, s_5 : store, da_lst : dataaddr*, s_6 : store, ea_lst : elemaddr*, xi_lst : exportinst*, var_18 : 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)) - -- fun_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, var_18) - -- (if ($proj_uN_0(x#4).0 < |dt_lst|))*{x#4 <- x_lst} - -- fun_allocfuncs: `%%%%%`(s_6, dt_lst[$proj_uN_0(x#4).0]*{x#4 <- x_lst}, FUNC_funccode(x#5, local_lst#86, expr_F#3)*{expr_F#3 <- expr_F_lst, local_lst#86 <- local_lst_lst, x#5 <- x_lst}, v_moduleinst^|func_lst|{}, var_17) - -- if (|var_16_lst| = |elemtype_lst|) - -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- dt_lst}, var_16))*{var_16 <- var_16_lst, elemtype#3 <- 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) - -- if (|var_13_lst| = |tabletype_lst|) - -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- dt_lst}, var_13))*{var_13 <- var_13_lst, tabletype#160 <- tabletype_lst} - -- fun_alloctables: `%%%%`(s_3, var_13_lst, ref_T_lst, var_12) - -- if (|var_11_lst| = |memtype_lst|) - -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- dt_lst}, var_11))*{var_11 <- var_11_lst, memtype#126 <- memtype_lst} - -- fun_allocmems: `%%%`(s_2, var_11_lst, var_10) - -- if (|var_9_lst| = |globaltype_lst|) - -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- dt_lst}, var_9))*{var_9 <- var_9_lst, globaltype#126 <- globaltype_lst} - -- fun_allocglobals: `%%%%`(s_1, var_9_lst, val_G_lst, var_8) - -- if (|var_7_lst| = |tagtype_lst|) - -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- dt_lst}, var_7))*{var_7 <- var_7_lst, tagtype#82 <- 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) -- wf_store: `%`(s_7) -- wf_moduleinst: `%`(v_moduleinst) -- wf_store: `%`(s_1) @@ -18842,6 +18814,31 @@ relation fun_allocmodule: `%%%%%%%`(store, module, externaddr*, val*, ref*, ref* -- if ((s_7, fa_lst) = var_17) -- if (xi_lst = var_18) -- 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}) + -- fun_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, var_18) + -- (if ($proj_uN_0(x#4).0 < |dt_lst|))*{x#4 <- x_lst} + -- fun_allocfuncs: `%%%%%`(s_6, dt_lst[$proj_uN_0(x#4).0]*{x#4 <- x_lst}, FUNC_funccode(x#5, local_lst#86, expr_F#3)*{expr_F#3 <- expr_F_lst, local_lst#86 <- local_lst_lst, x#5 <- x_lst}, v_moduleinst^|func_lst|{}, var_17) + -- if (|var_16_lst| = |elemtype_lst|) + -- (fun_subst_all_reftype: `%%%`(elemtype#3, $typeuse_deftype(dt#14)*{dt#14 <- dt_lst}, var_16))*{var_16 <- var_16_lst, elemtype#3 <- 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) + -- if (|var_13_lst| = |tabletype_lst|) + -- (fun_subst_all_tabletype: `%%%`(tabletype#160, $typeuse_deftype(dt#13)*{dt#13 <- dt_lst}, var_13))*{var_13 <- var_13_lst, tabletype#160 <- tabletype_lst} + -- fun_alloctables: `%%%%`(s_3, var_13_lst, ref_T_lst, var_12) + -- if (|var_11_lst| = |memtype_lst|) + -- (fun_subst_all_memtype: `%%%`(memtype#126, $typeuse_deftype(dt#12)*{dt#12 <- dt_lst}, var_11))*{var_11 <- var_11_lst, memtype#126 <- memtype_lst} + -- fun_allocmems: `%%%`(s_2, var_11_lst, var_10) + -- if (|var_9_lst| = |globaltype_lst|) + -- (fun_subst_all_globaltype: `%%%`(globaltype#126, $typeuse_deftype(dt#11)*{dt#11 <- dt_lst}, var_9))*{var_9 <- var_9_lst, globaltype#126 <- globaltype_lst} + -- fun_allocglobals: `%%%%`(s_1, var_9_lst, val_G_lst, var_8) + -- if (|var_7_lst| = |tagtype_lst|) + -- (fun_subst_all_tagtype: `%%%`(tagtype#82, $typeuse_deftype(dt#10)*{dt#10 <- dt_lst}, var_7))*{var_7 <- var_7_lst, tagtype#82 <- 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 fun_rundata_: `%%%`(dataidx, data, instr*) @@ -18888,13 +18885,13 @@ relation fun_evalexprs: `%%%`(state, expr*, (state, ref*)) ;; ../../../../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*, z'' : state, v_ref : ref, ref'_lst : ref*, z' : state, var_0 : (state, ref*)}: `%%%`(z, [v_expr] ++ expr'_lst, (z'', [v_ref] ++ ref'_lst)) - -- fun_evalexprs: `%%%`(z', expr'_lst, var_0) -- wf_state: `%`(z'') -- wf_ref: `%`(v_ref) -- (wf_ref: `%`(ref'#5))*{ref'#5 <- ref'_lst} -- wf_state: `%`(z') -- Eval_expr: `%;%~>*%;%`(z, v_expr, z', [$val_ref(v_ref)]) -- if ((z'', ref'_lst) = var_0) + -- fun_evalexprs: `%%%`(z', expr'_lst, var_0) } ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec @@ -18909,14 +18906,14 @@ relation fun_evalexprss: `%%%`(state, expr**, (state, ref**)) ;; ../../../../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**, z'' : state, ref_lst : ref*, ref'_lst_lst : ref**, z' : state, var_1 : (state, ref**), var_0 : (state, ref*)}: `%%%`(z, [expr_lst] ++ expr'_lst_lst, (z'', [ref_lst] ++ ref'_lst_lst)) - -- fun_evalexprss: `%%%`(z', expr'_lst_lst, var_1) - -- fun_evalexprs: `%%%`(z, expr_lst, var_0) -- wf_state: `%`(z'') -- (wf_ref: `%`(ref#6))*{ref#6 <- ref_lst} -- (wf_ref: `%`(ref'#7))*{ref'#7 <- ref'_lst#3}*{ref'_lst#3 <- ref'_lst_lst} -- wf_state: `%`(z') -- if ((z', ref_lst) = var_0) -- if ((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 @@ -18931,8 +18928,6 @@ 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_1{z : state, gt : globaltype, gt'_lst : globaltype*, v_expr : instr*, expr'_lst : expr*, z'' : state, v_val : val, val'_lst : val*, z' : state, s : store, f : frame, s' : store, a : nat, var_1 : (state, val*), var_0 : (store, globaladdr)}: `%%%%`(z, [gt] ++ gt'_lst, [v_expr] ++ expr'_lst, (z'', [v_val] ++ val'_lst)) - -- fun_evalglobals: `%%%%`(`%;%`_state(s', f[MODULE_frame.GLOBALS_moduleinst =++ [a]]), gt'_lst, expr'_lst, var_1) - -- fun_allocglobal: `%%%%`(s, gt, v_val, var_0) -- wf_state: `%`(z'') -- wf_val: `%`(v_val) -- (wf_val: `%`(val'#3))*{val'#3 <- val'_lst} @@ -18943,6 +18938,8 @@ relation fun_evalglobals: `%%%%`(state, globaltype*, expr*, (state, val*)) -- if (z' = `%;%`_state(s, f)) -- if ((s', a) = var_0) -- if ((z'', val'_lst) = var_1) + -- fun_evalglobals: `%%%%`(`%;%`_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 @@ -18950,20 +18947,6 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) ;; ../../../../specification/wasm-3.0/4.4-execution.modules.spectec rule fun_instantiate_case_0{s : store, v_module : module, externaddr_lst : externaddr*, s'''' : store, v_moduleinst : moduleinst, instr_E_lst : instr*, instr_D_lst : instr*, instr_S_opt : instr?, xt_I_lst : externtype*, xt_E_lst : externtype*, 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*, 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, z' : state, val_G_lst : val*, z'' : state, ref_T_lst : ref*, z''' : state, ref_E_lst_lst : ref**, s''' : store, f : frame, i_D : nat, i_E : nat, var_11_lst : instr**, var_10_lst : instr**, var_9 : (store, moduleinst), var_8 : (state, ref**), var_7 : (state, ref*), var_6 : (state, val*), var_5 : funcaddr*, var_4 : globaladdr*, var_3 : deftype*, var_2 : funcaddr*, var_1 : globaladdr*, var_0 : deftype*}: `%%%%`(s, v_module, externaddr_lst, `%;%`_config(`%;%`_state(s'''', {LOCALS [], MODULE v_moduleinst}), instr_E_lst ++ instr_D_lst ++ lift(instr_S_opt))) - -- (if (i_E#2 < |elem_lst|))^(i_E#2<|elem_lst|){} - -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem_lst[i_E#2], var_11))^(i_E#2<|elem_lst|){var_11 <- var_11_lst} - -- (if (i_D#2 < |data_lst|))^(i_D#2<|data_lst|){} - -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data_lst[i_D#2], var_10))^(i_D#2<|data_lst|){var_10 <- var_10_lst} - -- fun_allocmodule: `%%%%%%%`(s''', v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst, var_9) - -- fun_evalexprss: `%%%`(z'', expr_E_lst_lst, var_8) - -- fun_evalexprs: `%%%`(z', expr_T_lst, var_7) - -- fun_evalglobals: `%%%%`(z, globaltype_lst, expr_G_lst, var_6) - -- fun_funcsxa: `%%`(externaddr_lst, var_5) - -- fun_globalsxa: `%%`(externaddr_lst, var_4) - -- fun_alloctypes: `%%`(type_lst, var_3) - -- fun_funcsxa: `%%`(externaddr_lst, var_2) - -- fun_globalsxa: `%%`(externaddr_lst, var_1) - -- fun_alloctypes: `%%`(type_lst, var_0) -- wf_state: `%`(z) -- wf_state: `%`(z') -- (wf_val: `%`(val_G#3))*{val_G#3 <- val_G_lst} @@ -19009,6 +18992,20 @@ relation fun_instantiate: `%%%%`(store, module, externaddr*, config) -- if (instr_D_lst = $concat_(syntax instr, var_10_lst)) -- if (instr_E_lst = $concat_(syntax instr, var_11_lst)) -- if (instr_S_opt = CALL_instr(x#9)?{x#9 <- x_opt}) + -- (if (i_E#2 < |elem_lst|))^(i_E#2<|elem_lst|){} + -- (fun_runelem_: `%%%`(`%`_elemidx(i_E#2), elem_lst[i_E#2], var_11))^(i_E#2<|elem_lst|){var_11 <- var_11_lst} + -- (if (i_D#2 < |data_lst|))^(i_D#2<|data_lst|){} + -- (fun_rundata_: `%%%`(`%`_dataidx(i_D#2), data_lst[i_D#2], var_10))^(i_D#2<|data_lst|){var_10 <- var_10_lst} + -- fun_allocmodule: `%%%%%%%`(s''', v_module, externaddr_lst, val_G_lst, ref_T_lst, ref_E_lst_lst, var_9) + -- fun_evalexprss: `%%%`(z'', expr_E_lst_lst, var_8) + -- fun_evalexprs: `%%%`(z', expr_T_lst, var_7) + -- fun_evalglobals: `%%%%`(z, globaltype_lst, expr_G_lst, var_6) + -- fun_funcsxa: `%%`(externaddr_lst, var_5) + -- fun_globalsxa: `%%`(externaddr_lst, var_4) + -- fun_alloctypes: `%%`(type_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 fun_invoke: `%%%%`(store, funcaddr, val*, config) @@ -19454,8 +19451,8 @@ relation fun_ordered: `%%`(decl*, bool) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec rule fun_ordered_case_0{decl_lst : decl*, var_0 : import*}: `%%`(decl_lst, true) - -- fun_importsd: `%%`(decl_lst, var_0) -- if (var_0 = []) + -- fun_importsd: `%%`(decl_lst, var_0) ;; ../../../../specification/wasm-3.0/6.4-text.modules.spectec 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*}: