2746 lines
154 KiB
Plaintext
2746 lines
154 KiB
Plaintext
(module
|
|
(func $i32.log (import "debug" "log") (param i32))
|
|
(func $i32.log_tee (import "debug" "log_tee") (param i32) (result i32))
|
|
;; No i64 interop with JS yet - but maybe coming with WebAssembly BigInt
|
|
;; So we can instead fake this by splitting the i64 into two i32 limbs,
|
|
;; however these are WASM functions using i32x2.log:
|
|
(func $i32x2.log (import "debug" "log") (param i32) (param i32))
|
|
(func $f32.log (import "debug" "log") (param f32))
|
|
(func $f32.log_tee (import "debug" "log_tee") (param f32) (result f32))
|
|
(func $f64.log (import "debug" "log") (param f64))
|
|
(func $f64.log_tee (import "debug" "log_tee") (param f64) (result f64))
|
|
|
|
(memory $0 1)
|
|
(export "memory" (memory $0))
|
|
|
|
;; i64 logging by splitting into two i32 limbs
|
|
(func $i64.log
|
|
(param $0 i64)
|
|
(call $i32x2.log
|
|
;; Upper limb
|
|
(i32.wrap/i64
|
|
(i64.shr_s (get_local $0)
|
|
(i64.const 32)))
|
|
;; Lower limb
|
|
(i32.wrap/i64 (get_local $0))))
|
|
|
|
(func $i64.log_tee
|
|
(param $0 i64)
|
|
(result i64)
|
|
(call $i64.log (get_local $0))
|
|
(return (get_local $0)))
|
|
|
|
(func $extend_sign (param $f i64)
|
|
(result i64)
|
|
|
|
(local $tmp i64)
|
|
|
|
(i64.shr_u (get_local $f) (i64.const 31))
|
|
(i64.const 32)
|
|
(i64.shl)
|
|
(tee_local $tmp)
|
|
(i64.shl (get_local $tmp) (i64.const 1))
|
|
(i64.or)
|
|
(tee_local $tmp)
|
|
(i64.shl (get_local $tmp) (i64.const 2))
|
|
(i64.or)
|
|
(tee_local $tmp)
|
|
(i64.shl (get_local $tmp) (i64.const 4))
|
|
(i64.or)
|
|
(tee_local $tmp)
|
|
(i64.shl (get_local $tmp) (i64.const 8))
|
|
(i64.or)
|
|
(tee_local $tmp)
|
|
(i64.shl (get_local $tmp) (i64.const 16))
|
|
(i64.or)
|
|
(get_local $f)
|
|
(i64.or))
|
|
|
|
(func $mul (export "mul") (param $h i32) (param $f i32) (param $g i32)
|
|
(local $f0 i64)
|
|
(local $f1 i64)
|
|
(local $f2 i64)
|
|
(local $f3 i64)
|
|
(local $f4 i64)
|
|
(local $f5 i64)
|
|
(local $f6 i64)
|
|
(local $f7 i64)
|
|
(local $f8 i64)
|
|
(local $f9 i64)
|
|
|
|
(local $g0 i64)
|
|
(local $g1 i64)
|
|
(local $g2 i64)
|
|
(local $g3 i64)
|
|
(local $g4 i64)
|
|
(local $g5 i64)
|
|
(local $g6 i64)
|
|
(local $g7 i64)
|
|
(local $g8 i64)
|
|
(local $g9 i64)
|
|
|
|
(local $h0 i64)
|
|
(local $h1 i64)
|
|
(local $h2 i64)
|
|
(local $h3 i64)
|
|
(local $h4 i64)
|
|
(local $h5 i64)
|
|
(local $h6 i64)
|
|
(local $h7 i64)
|
|
(local $h8 i64)
|
|
(local $h9 i64)
|
|
|
|
(local $tmp i64)
|
|
|
|
(local $carry0 i64)
|
|
(local $carry1 i64)
|
|
(local $carry2 i64)
|
|
(local $carry3 i64)
|
|
(local $carry4 i64)
|
|
(local $carry5 i64)
|
|
(local $carry6 i64)
|
|
(local $carry7 i64)
|
|
(local $carry8 i64)
|
|
(local $carry9 i64)
|
|
|
|
(local $g1_19 i64)
|
|
(local $g2_19 i64)
|
|
(local $g3_19 i64)
|
|
(local $g4_19 i64)
|
|
(local $g5_19 i64)
|
|
(local $g6_19 i64)
|
|
(local $g7_19 i64)
|
|
(local $g8_19 i64)
|
|
(local $g9_19 i64)
|
|
(local $f1_2 i64)
|
|
(local $f3_2 i64)
|
|
(local $f5_2 i64)
|
|
(local $f7_2 i64)
|
|
(local $f9_2 i64)
|
|
|
|
(local $f0g0 i64)
|
|
(local $f0g1 i64)
|
|
(local $f0g2 i64)
|
|
(local $f0g3 i64)
|
|
(local $f0g4 i64)
|
|
(local $f0g5 i64)
|
|
(local $f0g6 i64)
|
|
(local $f0g7 i64)
|
|
(local $f0g8 i64)
|
|
(local $f0g9 i64)
|
|
(local $f1g0 i64)
|
|
(local $f1g1_2 i64)
|
|
(local $f1g2 i64)
|
|
(local $f1g3_2 i64)
|
|
(local $f1g4 i64)
|
|
(local $f1g5_2 i64)
|
|
(local $f1g6 i64)
|
|
(local $f1g7_2 i64)
|
|
(local $f1g8 i64)
|
|
(local $f1g9_38 i64)
|
|
(local $f2g0 i64)
|
|
(local $f2g1 i64)
|
|
(local $f2g2 i64)
|
|
(local $f2g3 i64)
|
|
(local $f2g4 i64)
|
|
(local $f2g5 i64)
|
|
(local $f2g6 i64)
|
|
(local $f2g7 i64)
|
|
(local $f2g8_19 i64)
|
|
(local $f2g9_19 i64)
|
|
(local $f3g0 i64)
|
|
(local $f3g1_2 i64)
|
|
(local $f3g2 i64)
|
|
(local $f3g3_2 i64)
|
|
(local $f3g4 i64)
|
|
(local $f3g5_2 i64)
|
|
(local $f3g6 i64)
|
|
(local $f3g7_38 i64)
|
|
(local $f3g8_19 i64)
|
|
(local $f3g9_38 i64)
|
|
(local $f4g0 i64)
|
|
(local $f4g1 i64)
|
|
(local $f4g2 i64)
|
|
(local $f4g3 i64)
|
|
(local $f4g4 i64)
|
|
(local $f4g5 i64)
|
|
(local $f4g6_19 i64)
|
|
(local $f4g7_19 i64)
|
|
(local $f4g8_19 i64)
|
|
(local $f4g9_19 i64)
|
|
(local $f5g0 i64)
|
|
(local $f5g1_2 i64)
|
|
(local $f5g2 i64)
|
|
(local $f5g3_2 i64)
|
|
(local $f5g4 i64)
|
|
(local $f5g5_38 i64)
|
|
(local $f5g6_19 i64)
|
|
(local $f5g7_38 i64)
|
|
(local $f5g8_19 i64)
|
|
(local $f5g9_38 i64)
|
|
(local $f6g0 i64)
|
|
(local $f6g1 i64)
|
|
(local $f6g2 i64)
|
|
(local $f6g3 i64)
|
|
(local $f6g4_19 i64)
|
|
(local $f6g5_19 i64)
|
|
(local $f6g6_19 i64)
|
|
(local $f6g7_19 i64)
|
|
(local $f6g8_19 i64)
|
|
(local $f6g9_19 i64)
|
|
(local $f7g0 i64)
|
|
(local $f7g1_2 i64)
|
|
(local $f7g2 i64)
|
|
(local $f7g3_38 i64)
|
|
(local $f7g4_19 i64)
|
|
(local $f7g5_38 i64)
|
|
(local $f7g6_19 i64)
|
|
(local $f7g7_38 i64)
|
|
(local $f7g8_19 i64)
|
|
(local $f7g9_38 i64)
|
|
(local $f8g0 i64)
|
|
(local $f8g1 i64)
|
|
(local $f8g2_19 i64)
|
|
(local $f8g3_19 i64)
|
|
(local $f8g4_19 i64)
|
|
(local $f8g5_19 i64)
|
|
(local $f8g6_19 i64)
|
|
(local $f8g7_19 i64)
|
|
(local $f8g8_19 i64)
|
|
(local $f8g9_19 i64)
|
|
(local $f9g0 i64)
|
|
(local $f9g1_38 i64)
|
|
(local $f9g2_19 i64)
|
|
(local $f9g3_38 i64)
|
|
(local $f9g4_19 i64)
|
|
(local $f9g5_38 i64)
|
|
(local $f9g6_19 i64)
|
|
(local $f9g7_38 i64)
|
|
(local $f9g8_19 i64)
|
|
(local $f9g9_38 i64)
|
|
|
|
(set_local $f0 (i64.load32_u offset=0 (get_local $f)))
|
|
(set_local $f1 (i64.load32_u offset=4 (get_local $f)))
|
|
(set_local $f2 (i64.load32_u offset=8 (get_local $f)))
|
|
(set_local $f3 (i64.load32_u offset=12 (get_local $f)))
|
|
(set_local $f4 (i64.load32_u offset=16 (get_local $f)))
|
|
(set_local $f5 (i64.load32_u offset=20 (get_local $f)))
|
|
(set_local $f6 (i64.load32_u offset=24 (get_local $f)))
|
|
(set_local $f7 (i64.load32_u offset=28 (get_local $f)))
|
|
(set_local $f8 (i64.load32_u offset=32 (get_local $f)))
|
|
(set_local $f9 (i64.load32_u offset=36 (get_local $f)))
|
|
|
|
(set_local $g0 (i64.load32_u offset=0 (get_local $g)))
|
|
(set_local $g1 (i64.load32_u offset=4 (get_local $g)))
|
|
(set_local $g2 (i64.load32_u offset=8 (get_local $g)))
|
|
(set_local $g3 (i64.load32_u offset=12 (get_local $g)))
|
|
(set_local $g4 (i64.load32_u offset=16 (get_local $g)))
|
|
(set_local $g5 (i64.load32_u offset=20 (get_local $g)))
|
|
(set_local $g6 (i64.load32_u offset=24 (get_local $g)))
|
|
(set_local $g7 (i64.load32_u offset=28 (get_local $g)))
|
|
(set_local $g8 (i64.load32_u offset=32 (get_local $g)))
|
|
(set_local $g9 (i64.load32_u offset=36 (get_local $g)))
|
|
|
|
(call $extend_sign (get_local $f0))
|
|
(set_local $f0)
|
|
(call $extend_sign (get_local $f1))
|
|
(set_local $f1)
|
|
(call $extend_sign (get_local $f2))
|
|
(set_local $f2)
|
|
(call $extend_sign (get_local $f3))
|
|
(set_local $f3)
|
|
(call $extend_sign (get_local $f4))
|
|
(set_local $f4)
|
|
(call $extend_sign (get_local $f5))
|
|
(set_local $f5)
|
|
(call $extend_sign (get_local $f6))
|
|
(set_local $f6)
|
|
(call $extend_sign (get_local $f7))
|
|
(set_local $f7)
|
|
(call $extend_sign (get_local $f8))
|
|
(set_local $f8)
|
|
(call $extend_sign (get_local $f9))
|
|
(set_local $f9)
|
|
|
|
(call $extend_sign (get_local $g0))
|
|
(set_local $g0)
|
|
(call $extend_sign (get_local $g1))
|
|
(set_local $g1)
|
|
(call $extend_sign (get_local $g2))
|
|
(set_local $g2)
|
|
(call $extend_sign (get_local $g3))
|
|
(set_local $g3)
|
|
(call $extend_sign (get_local $g4))
|
|
(set_local $g4)
|
|
(call $extend_sign (get_local $g5))
|
|
(set_local $g5)
|
|
(call $extend_sign (get_local $g6))
|
|
(set_local $g6)
|
|
(call $extend_sign (get_local $g7))
|
|
(set_local $g7)
|
|
(call $extend_sign (get_local $g8))
|
|
(set_local $g8)
|
|
(call $extend_sign (get_local $g9))
|
|
(set_local $g9)
|
|
|
|
(set_local $g1_19 (i64.sub (i64.mul (i64.const 19) (get_local $g1)) (i64.mul (i64.shl (i64.and (get_local $g1) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
(set_local $g2_19 (i64.sub (i64.mul (i64.const 19) (get_local $g2)) (i64.mul (i64.shl (i64.and (get_local $g2) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
(set_local $g3_19 (i64.sub (i64.mul (i64.const 19) (get_local $g3)) (i64.mul (i64.shl (i64.and (get_local $g3) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
(set_local $g4_19 (i64.sub (i64.mul (i64.const 19) (get_local $g4)) (i64.mul (i64.shl (i64.and (get_local $g4) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
(set_local $g5_19 (i64.sub (i64.mul (i64.const 19) (get_local $g5)) (i64.mul (i64.shl (i64.and (get_local $g5) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
(set_local $g6_19 (i64.sub (i64.mul (i64.const 19) (get_local $g6)) (i64.mul (i64.shl (i64.and (get_local $g6) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
(set_local $g7_19 (i64.sub (i64.mul (i64.const 19) (get_local $g7)) (i64.mul (i64.shl (i64.and (get_local $g7) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
(set_local $g8_19 (i64.sub (i64.mul (i64.const 19) (get_local $g8)) (i64.mul (i64.shl (i64.and (get_local $g8) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
(set_local $g9_19 (i64.sub (i64.mul (i64.const 19) (get_local $g9)) (i64.mul (i64.shl (i64.and (get_local $g9) (i64.const 0x80000000)) (i64.const 1)) (i64.const 19))))
|
|
|
|
(set_local $f1_2 (i64.sub (i64.mul (i64.const 2) (get_local $f1)) (i64.mul (i64.shl (i64.and (get_local $f1) (i64.const 0x80000000)) (i64.const 1)) (i64.const 2))))
|
|
(set_local $f3_2 (i64.sub (i64.mul (i64.const 2) (get_local $f3)) (i64.mul (i64.shl (i64.and (get_local $f3) (i64.const 0x80000000)) (i64.const 1)) (i64.const 2))))
|
|
(set_local $f5_2 (i64.sub (i64.mul (i64.const 2) (get_local $f5)) (i64.mul (i64.shl (i64.and (get_local $f5) (i64.const 0x80000000)) (i64.const 1)) (i64.const 2))))
|
|
(set_local $f7_2 (i64.sub (i64.mul (i64.const 2) (get_local $f7)) (i64.mul (i64.shl (i64.and (get_local $f7) (i64.const 0x80000000)) (i64.const 1)) (i64.const 2))))
|
|
(set_local $f9_2 (i64.sub (i64.mul (i64.const 2) (get_local $f9)) (i64.mul (i64.shl (i64.and (get_local $f9) (i64.const 0x80000000)) (i64.const 1)) (i64.const 2))))
|
|
|
|
(call $extend_sign (get_local $g1_19))
|
|
(set_local $g1_19)
|
|
(call $extend_sign (get_local $g2_19))
|
|
(set_local $g2_19)
|
|
(call $extend_sign (get_local $g3_19))
|
|
(set_local $g3_19)
|
|
(call $extend_sign (get_local $g4_19))
|
|
(set_local $g4_19)
|
|
(call $extend_sign (get_local $g5_19))
|
|
(set_local $g5_19)
|
|
(call $extend_sign (get_local $g6_19))
|
|
(set_local $g6_19)
|
|
(call $extend_sign (get_local $g7_19))
|
|
(set_local $g7_19)
|
|
(call $extend_sign (get_local $g8_19))
|
|
(set_local $g8_19)
|
|
(call $extend_sign (get_local $g9_19))
|
|
(set_local $g9_19)
|
|
|
|
(call $extend_sign (get_local $f1_2))
|
|
(set_local $f1_2)
|
|
(call $extend_sign (get_local $f3_2))
|
|
(set_local $f3_2)
|
|
(call $extend_sign (get_local $f5_2))
|
|
(set_local $f5_2)
|
|
(call $extend_sign (get_local $f7_2))
|
|
(set_local $f7_2)
|
|
(call $extend_sign (get_local $f9_2))
|
|
(set_local $f9_2)
|
|
|
|
(set_local $f0g0 (i64.mul (get_local $f0 ) (get_local $g0)))
|
|
(set_local $f0g1 (i64.mul (get_local $f0 ) (get_local $g1)))
|
|
(set_local $f0g2 (i64.mul (get_local $f0 ) (get_local $g2)))
|
|
(set_local $f0g3 (i64.mul (get_local $f0 ) (get_local $g3)))
|
|
(set_local $f0g4 (i64.mul (get_local $f0 ) (get_local $g4)))
|
|
(set_local $f0g5 (i64.mul (get_local $f0 ) (get_local $g5)))
|
|
(set_local $f0g6 (i64.mul (get_local $f0 ) (get_local $g6)))
|
|
(set_local $f0g7 (i64.mul (get_local $f0 ) (get_local $g7)))
|
|
(set_local $f0g8 (i64.mul (get_local $f0 ) (get_local $g8)))
|
|
(set_local $f0g9 (i64.mul (get_local $f0 ) (get_local $g9)))
|
|
(set_local $f1g0 (i64.mul (get_local $f1 ) (get_local $g0)))
|
|
(set_local $f1g1_2 (i64.mul (get_local $f1_2) (get_local $g1)))
|
|
(set_local $f1g2 (i64.mul (get_local $f1 ) (get_local $g2)))
|
|
(set_local $f1g3_2 (i64.mul (get_local $f1_2) (get_local $g3)))
|
|
(set_local $f1g4 (i64.mul (get_local $f1 ) (get_local $g4)))
|
|
(set_local $f1g5_2 (i64.mul (get_local $f1_2) (get_local $g5)))
|
|
(set_local $f1g6 (i64.mul (get_local $f1 ) (get_local $g6)))
|
|
(set_local $f1g7_2 (i64.mul (get_local $f1_2) (get_local $g7)))
|
|
(set_local $f1g8 (i64.mul (get_local $f1 ) (get_local $g8)))
|
|
(set_local $f1g9_38 (i64.mul (get_local $f1_2) (get_local $g9_19)))
|
|
(set_local $f2g0 (i64.mul (get_local $f2 ) (get_local $g0)))
|
|
(set_local $f2g1 (i64.mul (get_local $f2 ) (get_local $g1)))
|
|
(set_local $f2g2 (i64.mul (get_local $f2 ) (get_local $g2)))
|
|
(set_local $f2g3 (i64.mul (get_local $f2 ) (get_local $g3)))
|
|
(set_local $f2g4 (i64.mul (get_local $f2 ) (get_local $g4)))
|
|
(set_local $f2g5 (i64.mul (get_local $f2 ) (get_local $g5)))
|
|
(set_local $f2g6 (i64.mul (get_local $f2 ) (get_local $g6)))
|
|
(set_local $f2g7 (i64.mul (get_local $f2 ) (get_local $g7)))
|
|
(set_local $f2g8_19 (i64.mul (get_local $f2 ) (get_local $g8_19)))
|
|
(set_local $f2g9_19 (i64.mul (get_local $f2 ) (get_local $g9_19)))
|
|
(set_local $f3g0 (i64.mul (get_local $f3 ) (get_local $g0)))
|
|
(set_local $f3g1_2 (i64.mul (get_local $f3_2) (get_local $g1)))
|
|
(set_local $f3g2 (i64.mul (get_local $f3 ) (get_local $g2)))
|
|
(set_local $f3g3_2 (i64.mul (get_local $f3_2) (get_local $g3)))
|
|
(set_local $f3g4 (i64.mul (get_local $f3 ) (get_local $g4)))
|
|
(set_local $f3g5_2 (i64.mul (get_local $f3_2) (get_local $g5)))
|
|
(set_local $f3g6 (i64.mul (get_local $f3 ) (get_local $g6)))
|
|
(set_local $f3g7_38 (i64.mul (get_local $f3_2) (get_local $g7_19)))
|
|
(set_local $f3g8_19 (i64.mul (get_local $f3 ) (get_local $g8_19)))
|
|
(set_local $f3g9_38 (i64.mul (get_local $f3_2) (get_local $g9_19)))
|
|
(set_local $f4g0 (i64.mul (get_local $f4) (get_local $g0)))
|
|
(set_local $f4g1 (i64.mul (get_local $f4) (get_local $g1)))
|
|
(set_local $f4g2 (i64.mul (get_local $f4) (get_local $g2)))
|
|
(set_local $f4g3 (i64.mul (get_local $f4) (get_local $g3)))
|
|
(set_local $f4g4 (i64.mul (get_local $f4) (get_local $g4)))
|
|
(set_local $f4g5 (i64.mul (get_local $f4) (get_local $g5)))
|
|
(set_local $f4g6_19 (i64.mul (get_local $f4) (get_local $g6_19)))
|
|
(set_local $f4g7_19 (i64.mul (get_local $f4) (get_local $g7_19)))
|
|
(set_local $f4g8_19 (i64.mul (get_local $f4) (get_local $g8_19)))
|
|
(set_local $f4g9_19 (i64.mul (get_local $f4) (get_local $g9_19)))
|
|
(set_local $f5g0 (i64.mul (get_local $f5) (get_local $g0)))
|
|
(set_local $f5g1_2 (i64.mul (get_local $f5_2) (get_local $g1)))
|
|
(set_local $f5g2 (i64.mul (get_local $f5) (get_local $g2)))
|
|
(set_local $f5g3_2 (i64.mul (get_local $f5_2) (get_local $g3)))
|
|
(set_local $f5g4 (i64.mul (get_local $f5) (get_local $g4)))
|
|
(set_local $f5g5_38 (i64.mul (get_local $f5_2) (get_local $g5_19)))
|
|
(set_local $f5g6_19 (i64.mul (get_local $f5) (get_local $g6_19)))
|
|
(set_local $f5g7_38 (i64.mul (get_local $f5_2) (get_local $g7_19)))
|
|
(set_local $f5g8_19 (i64.mul (get_local $f5) (get_local $g8_19)))
|
|
(set_local $f5g9_38 (i64.mul (get_local $f5_2) (get_local $g9_19)))
|
|
(set_local $f6g0 (i64.mul (get_local $f6) (get_local $g0)))
|
|
(set_local $f6g1 (i64.mul (get_local $f6) (get_local $g1)))
|
|
(set_local $f6g2 (i64.mul (get_local $f6) (get_local $g2)))
|
|
(set_local $f6g3 (i64.mul (get_local $f6) (get_local $g3)))
|
|
(set_local $f6g4_19 (i64.mul (get_local $f6) (get_local $g4_19)))
|
|
(set_local $f6g5_19 (i64.mul (get_local $f6) (get_local $g5_19)))
|
|
(set_local $f6g6_19 (i64.mul (get_local $f6) (get_local $g6_19)))
|
|
(set_local $f6g7_19 (i64.mul (get_local $f6) (get_local $g7_19)))
|
|
(set_local $f6g8_19 (i64.mul (get_local $f6) (get_local $g8_19)))
|
|
(set_local $f6g9_19 (i64.mul (get_local $f6) (get_local $g9_19)))
|
|
(set_local $f7g0 (i64.mul (get_local $f7) (get_local $g0)))
|
|
(set_local $f7g1_2 (i64.mul (get_local $f7_2) (get_local $g1)))
|
|
(set_local $f7g2 (i64.mul (get_local $f7) (get_local $g2)))
|
|
(set_local $f7g3_38 (i64.mul (get_local $f7_2) (get_local $g3_19)))
|
|
(set_local $f7g4_19 (i64.mul (get_local $f7) (get_local $g4_19)))
|
|
(set_local $f7g5_38 (i64.mul (get_local $f7_2) (get_local $g5_19)))
|
|
(set_local $f7g6_19 (i64.mul (get_local $f7) (get_local $g6_19)))
|
|
(set_local $f7g7_38 (i64.mul (get_local $f7_2) (get_local $g7_19)))
|
|
(set_local $f7g8_19 (i64.mul (get_local $f7) (get_local $g8_19)))
|
|
(set_local $f7g9_38 (i64.mul (get_local $f7_2) (get_local $g9_19)))
|
|
(set_local $f8g0 (i64.mul (get_local $f8) (get_local $g0)))
|
|
(set_local $f8g1 (i64.mul (get_local $f8) (get_local $g1)))
|
|
(set_local $f8g2_19 (i64.mul (get_local $f8) (get_local $g2_19)))
|
|
(set_local $f8g3_19 (i64.mul (get_local $f8) (get_local $g3_19)))
|
|
(set_local $f8g4_19 (i64.mul (get_local $f8) (get_local $g4_19)))
|
|
(set_local $f8g5_19 (i64.mul (get_local $f8) (get_local $g5_19)))
|
|
(set_local $f8g6_19 (i64.mul (get_local $f8) (get_local $g6_19)))
|
|
(set_local $f8g7_19 (i64.mul (get_local $f8) (get_local $g7_19)))
|
|
(set_local $f8g8_19 (i64.mul (get_local $f8) (get_local $g8_19)))
|
|
(set_local $f8g9_19 (i64.mul (get_local $f8) (get_local $g9_19)))
|
|
(set_local $f9g0 (i64.mul (get_local $f9) (get_local $g0)))
|
|
(set_local $f9g1_38 (i64.mul (get_local $f9_2) (get_local $g1_19)))
|
|
(set_local $f9g2_19 (i64.mul (get_local $f9) (get_local $g2_19)))
|
|
(set_local $f9g3_38 (i64.mul (get_local $f9_2) (get_local $g3_19)))
|
|
(set_local $f9g4_19 (i64.mul (get_local $f9) (get_local $g4_19)))
|
|
(set_local $f9g5_38 (i64.mul (get_local $f9_2) (get_local $g5_19)))
|
|
(set_local $f9g6_19 (i64.mul (get_local $f9) (get_local $g6_19)))
|
|
(set_local $f9g7_38 (i64.mul (get_local $f9_2) (get_local $g7_19)))
|
|
(set_local $f9g8_19 (i64.mul (get_local $f9) (get_local $g8_19)))
|
|
(set_local $f9g9_38 (i64.mul (get_local $f9_2) (get_local $g9_19)))
|
|
|
|
(set_local $h0 (i64.add (get_local $f0g0) (i64.add (get_local $f1g9_38) (i64.add (get_local $f2g8_19) (i64.add (get_local $f3g7_38) (i64.add (get_local $f4g6_19) (i64.add (get_local $f5g5_38) (i64.add (get_local $f6g4_19) (i64.add (get_local $f7g3_38) (i64.add (get_local $f8g2_19) (get_local $f9g1_38)))))))))))
|
|
(set_local $h1 (i64.add (get_local $f0g1) (i64.add (get_local $f1g0) (i64.add (get_local $f2g9_19) (i64.add (get_local $f3g8_19) (i64.add (get_local $f4g7_19) (i64.add (get_local $f5g6_19) (i64.add (get_local $f6g5_19) (i64.add (get_local $f7g4_19) (i64.add (get_local $f8g3_19) (get_local $f9g2_19)))))))))))
|
|
(set_local $h2 (i64.add (get_local $f0g2) (i64.add (get_local $f1g1_2) (i64.add (get_local $f2g0) (i64.add (get_local $f3g9_38) (i64.add (get_local $f4g8_19) (i64.add (get_local $f5g7_38) (i64.add (get_local $f6g6_19) (i64.add (get_local $f7g5_38) (i64.add (get_local $f8g4_19) (get_local $f9g3_38)))))))))))
|
|
(set_local $h3 (i64.add (get_local $f0g3) (i64.add (get_local $f1g2) (i64.add (get_local $f2g1) (i64.add (get_local $f3g0) (i64.add (get_local $f4g9_19) (i64.add (get_local $f5g8_19) (i64.add (get_local $f6g7_19) (i64.add (get_local $f7g6_19) (i64.add (get_local $f8g5_19) (get_local $f9g4_19)))))))))))
|
|
(set_local $h4 (i64.add (get_local $f0g4) (i64.add (get_local $f1g3_2) (i64.add (get_local $f2g2) (i64.add (get_local $f3g1_2) (i64.add (get_local $f4g0) (i64.add (get_local $f5g9_38) (i64.add (get_local $f6g8_19) (i64.add (get_local $f7g7_38) (i64.add (get_local $f8g6_19) (get_local $f9g5_38)))))))))))
|
|
(set_local $h5 (i64.add (get_local $f0g5) (i64.add (get_local $f1g4) (i64.add (get_local $f2g3) (i64.add (get_local $f3g2) (i64.add (get_local $f4g1) (i64.add (get_local $f5g0) (i64.add (get_local $f6g9_19) (i64.add (get_local $f7g8_19) (i64.add (get_local $f8g7_19) (get_local $f9g6_19)))))))))))
|
|
(set_local $h6 (i64.add (get_local $f0g6) (i64.add (get_local $f1g5_2) (i64.add (get_local $f2g4) (i64.add (get_local $f3g3_2) (i64.add (get_local $f4g2) (i64.add (get_local $f5g1_2) (i64.add (get_local $f6g0) (i64.add (get_local $f7g9_38) (i64.add (get_local $f8g8_19) (get_local $f9g7_38)))))))))))
|
|
(set_local $h7 (i64.add (get_local $f0g7) (i64.add (get_local $f1g6) (i64.add (get_local $f2g5) (i64.add (get_local $f3g4) (i64.add (get_local $f4g3) (i64.add (get_local $f5g2) (i64.add (get_local $f6g1) (i64.add (get_local $f7g0) (i64.add (get_local $f8g9_19) (get_local $f9g8_19)))))))))))
|
|
(set_local $h8 (i64.add (get_local $f0g8) (i64.add (get_local $f1g7_2) (i64.add (get_local $f2g6) (i64.add (get_local $f3g5_2) (i64.add (get_local $f4g4) (i64.add (get_local $f5g3_2) (i64.add (get_local $f6g2) (i64.add (get_local $f7g1_2) (i64.add (get_local $f8g0) (get_local $f9g9_38)))))))))))
|
|
(set_local $h9 (i64.add (get_local $f0g9) (i64.add (get_local $f1g8) (i64.add (get_local $f2g7) (i64.add (get_local $f3g6) (i64.add (get_local $f4g5) (i64.add (get_local $f5g4) (i64.add (get_local $f6g3) (i64.add (get_local $f7g2) (i64.add (get_local $f8g1) (get_local $f9g0)))))))))))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $h0) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h1 (i64.add (get_local $h1) (get_local $carry0)))
|
|
(set_local $h0 (i64.sub (get_local $h0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $h4) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h5 (i64.add (get_local $h5) (get_local $carry4)))
|
|
(set_local $h4 (i64.sub (get_local $h4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (i64.add (get_local $h1) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h2 (i64.add (get_local $h2) (get_local $carry1)))
|
|
(set_local $h1 (i64.sub (get_local $h1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
(set_local $carry5 (i64.shr_s (i64.add (get_local $h5) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h6 (i64.add (get_local $h6) (get_local $carry5)))
|
|
(set_local $h5 (i64.sub (get_local $h5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (i64.add (get_local $h2) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h3 (i64.add (get_local $h3) (get_local $carry2)))
|
|
(set_local $h2 (i64.sub (get_local $h2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $h6) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h7 (i64.add (get_local $h7) (get_local $carry6)))
|
|
(set_local $h6 (i64.sub (get_local $h6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (i64.add (get_local $h3) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h4 (i64.add (get_local $h4) (get_local $carry3)))
|
|
(set_local $h3 (i64.sub (get_local $h3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $h7) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h8 (i64.add (get_local $h8) (get_local $carry7)))
|
|
(set_local $h7 (i64.sub (get_local $h7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $h4) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h5 (i64.add (get_local $h5) (get_local $carry4)))
|
|
(set_local $h4 (i64.sub (get_local $h4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $h8) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h9 (i64.add (get_local $h9) (get_local $carry8)))
|
|
(set_local $h8 (i64.sub (get_local $h8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $h9) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h0 (i64.add (get_local $h0) (i64.mul (get_local $carry9) (i64.const 19))))
|
|
(set_local $h9 (i64.sub (get_local $h9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $h0) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h1 (i64.add (get_local $h1) (get_local $carry0)))
|
|
(set_local $h0 (i64.sub (get_local $h0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
|
|
(i64.store32 offset=0 (get_local $h) (get_local $h0))
|
|
(i64.store32 offset=4 (get_local $h) (get_local $h1))
|
|
(i64.store32 offset=8 (get_local $h) (get_local $h2))
|
|
(i64.store32 offset=12 (get_local $h) (get_local $h3))
|
|
(i64.store32 offset=16 (get_local $h) (get_local $h4))
|
|
(i64.store32 offset=20 (get_local $h) (get_local $h5))
|
|
(i64.store32 offset=24 (get_local $h) (get_local $h6))
|
|
(i64.store32 offset=28 (get_local $h) (get_local $h7))
|
|
(i64.store32 offset=32 (get_local $h) (get_local $h8))
|
|
(i64.store32 offset=36 (get_local $h) (get_local $h9)))
|
|
|
|
(func $sq (export "sq") (param $h i32) (param $f i32) (param $double i32)
|
|
(local $tmp i64)
|
|
|
|
(local $f0 i64)
|
|
(local $f1 i64)
|
|
(local $f2 i64)
|
|
(local $f3 i64)
|
|
(local $f4 i64)
|
|
(local $f5 i64)
|
|
(local $f6 i64)
|
|
(local $f7 i64)
|
|
(local $f8 i64)
|
|
(local $f9 i64)
|
|
|
|
(local $h0 i64)
|
|
(local $h1 i64)
|
|
(local $h2 i64)
|
|
(local $h3 i64)
|
|
(local $h4 i64)
|
|
(local $h5 i64)
|
|
(local $h6 i64)
|
|
(local $h7 i64)
|
|
(local $h8 i64)
|
|
(local $h9 i64)
|
|
|
|
(local $carry0 i64)
|
|
(local $carry1 i64)
|
|
(local $carry2 i64)
|
|
(local $carry3 i64)
|
|
(local $carry4 i64)
|
|
(local $carry5 i64)
|
|
(local $carry6 i64)
|
|
(local $carry7 i64)
|
|
(local $carry8 i64)
|
|
(local $carry9 i64)
|
|
|
|
(local $f0_2 i64)
|
|
(local $f1_2 i64)
|
|
(local $f2_2 i64)
|
|
(local $f3_2 i64)
|
|
(local $f4_2 i64)
|
|
(local $f5_2 i64)
|
|
(local $f6_2 i64)
|
|
(local $f7_2 i64)
|
|
|
|
(local $f5_38 i64)
|
|
(local $f6_19 i64)
|
|
(local $f7_38 i64)
|
|
(local $f8_19 i64)
|
|
(local $f9_38 i64)
|
|
|
|
(local $f0f0 i64)
|
|
(local $f0f1_2 i64)
|
|
(local $f0f2_2 i64)
|
|
(local $f0f3_2 i64)
|
|
(local $f0f4_2 i64)
|
|
(local $f0f5_2 i64)
|
|
(local $f0f6_2 i64)
|
|
(local $f0f7_2 i64)
|
|
(local $f0f8_2 i64)
|
|
(local $f0f9_2 i64)
|
|
(local $f1f1_2 i64)
|
|
(local $f1f2_2 i64)
|
|
(local $f1f3_4 i64)
|
|
(local $f1f4_2 i64)
|
|
(local $f1f5_4 i64)
|
|
(local $f1f6_2 i64)
|
|
(local $f1f7_4 i64)
|
|
(local $f1f8_2 i64)
|
|
(local $f1f9_76 i64)
|
|
(local $f2f2 i64)
|
|
(local $f2f3_2 i64)
|
|
(local $f2f4_2 i64)
|
|
(local $f2f5_2 i64)
|
|
(local $f2f6_2 i64)
|
|
(local $f2f7_2 i64)
|
|
(local $f2f8_38 i64)
|
|
(local $f2f9_38 i64)
|
|
(local $f3f3_2 i64)
|
|
(local $f3f4_2 i64)
|
|
(local $f3f5_4 i64)
|
|
(local $f3f6_2 i64)
|
|
(local $f3f7_76 i64)
|
|
(local $f3f8_38 i64)
|
|
(local $f3f9_76 i64)
|
|
(local $f4f4 i64)
|
|
(local $f4f5_2 i64)
|
|
(local $f4f6_38 i64)
|
|
(local $f4f7_38 i64)
|
|
(local $f4f8_38 i64)
|
|
(local $f4f9_38 i64)
|
|
(local $f5f5_38 i64)
|
|
(local $f5f6_38 i64)
|
|
(local $f5f7_76 i64)
|
|
(local $f5f8_38 i64)
|
|
(local $f5f9_76 i64)
|
|
(local $f6f6_19 i64)
|
|
(local $f6f7_38 i64)
|
|
(local $f6f8_38 i64)
|
|
(local $f6f9_38 i64)
|
|
(local $f7f7_38 i64)
|
|
(local $f7f8_38 i64)
|
|
(local $f7f9_76 i64)
|
|
(local $f8f8_19 i64)
|
|
(local $f8f9_38 i64)
|
|
(local $f9f9_38 i64)
|
|
|
|
(set_local $f0 (i64.load32_u offset=0 (get_local $f)))
|
|
(set_local $f1 (i64.load32_u offset=4 (get_local $f)))
|
|
(set_local $f2 (i64.load32_u offset=8 (get_local $f)))
|
|
(set_local $f3 (i64.load32_u offset=12 (get_local $f)))
|
|
(set_local $f4 (i64.load32_u offset=16 (get_local $f)))
|
|
(set_local $f5 (i64.load32_u offset=20 (get_local $f)))
|
|
(set_local $f6 (i64.load32_u offset=24 (get_local $f)))
|
|
(set_local $f7 (i64.load32_u offset=28 (get_local $f)))
|
|
(set_local $f8 (i64.load32_u offset=32 (get_local $f)))
|
|
(set_local $f9 (i64.load32_u offset=36 (get_local $f)))
|
|
|
|
(call $extend_sign (get_local $f0))
|
|
(set_local $f0)
|
|
(call $extend_sign (get_local $f1))
|
|
(set_local $f1)
|
|
(call $extend_sign (get_local $f2))
|
|
(set_local $f2)
|
|
(call $extend_sign (get_local $f3))
|
|
(set_local $f3)
|
|
(call $extend_sign (get_local $f4))
|
|
(set_local $f4)
|
|
(call $extend_sign (get_local $f5))
|
|
(set_local $f5)
|
|
(call $extend_sign (get_local $f6))
|
|
(set_local $f6)
|
|
(call $extend_sign (get_local $f7))
|
|
(set_local $f7)
|
|
(call $extend_sign (get_local $f8))
|
|
(set_local $f8)
|
|
(call $extend_sign (get_local $f9))
|
|
(set_local $f9)
|
|
|
|
(set_local $f0_2 (i64.mul (i64.const 2 (get_local $f0))))
|
|
(set_local $f1_2 (i64.mul (i64.const 2 (get_local $f1))))
|
|
(set_local $f2_2 (i64.mul (i64.const 2 (get_local $f2))))
|
|
(set_local $f3_2 (i64.mul (i64.const 2 (get_local $f3))))
|
|
(set_local $f4_2 (i64.mul (i64.const 2 (get_local $f4))))
|
|
(set_local $f5_2 (i64.mul (i64.const 2 (get_local $f5))))
|
|
(set_local $f6_2 (i64.mul (i64.const 2 (get_local $f6))))
|
|
(set_local $f7_2 (i64.mul (i64.const 2 (get_local $f7))))
|
|
|
|
(set_local $f5_38 (i64.mul (i64.const 38 (get_local $f5))))
|
|
(set_local $f6_19 (i64.mul (i64.const 19 (get_local $f6))))
|
|
(set_local $f7_38 (i64.mul (i64.const 38 (get_local $f7))))
|
|
(set_local $f8_19 (i64.mul (i64.const 19 (get_local $f8))))
|
|
(set_local $f9_38 (i64.mul (i64.const 38 (get_local $f9))))
|
|
|
|
(set_local $f0f0 (i64.mul (get_local $f0) (get_local $f0)))
|
|
(set_local $f0f1_2 (i64.mul (get_local $f0_2) (get_local $f1)))
|
|
(set_local $f0f2_2 (i64.mul (get_local $f0_2) (get_local $f2)))
|
|
(set_local $f0f3_2 (i64.mul (get_local $f0_2) (get_local $f3)))
|
|
(set_local $f0f4_2 (i64.mul (get_local $f0_2) (get_local $f4)))
|
|
(set_local $f0f5_2 (i64.mul (get_local $f0_2) (get_local $f5)))
|
|
(set_local $f0f6_2 (i64.mul (get_local $f0_2) (get_local $f6)))
|
|
(set_local $f0f7_2 (i64.mul (get_local $f0_2) (get_local $f7)))
|
|
(set_local $f0f8_2 (i64.mul (get_local $f0_2) (get_local $f8)))
|
|
(set_local $f0f9_2 (i64.mul (get_local $f0_2) (get_local $f9)))
|
|
(set_local $f1f1_2 (i64.mul (get_local $f1_2) (get_local $f1)))
|
|
(set_local $f1f2_2 (i64.mul (get_local $f1_2) (get_local $f2)))
|
|
(set_local $f1f3_4 (i64.mul (get_local $f1_2) (get_local $f3_2)))
|
|
(set_local $f1f4_2 (i64.mul (get_local $f1_2) (get_local $f4)))
|
|
(set_local $f1f5_4 (i64.mul (get_local $f1_2) (get_local $f5_2)))
|
|
(set_local $f1f6_2 (i64.mul (get_local $f1_2) (get_local $f6)))
|
|
(set_local $f1f7_4 (i64.mul (get_local $f1_2) (get_local $f7_2)))
|
|
(set_local $f1f8_2 (i64.mul (get_local $f1_2) (get_local $f8)))
|
|
(set_local $f1f9_76 (i64.mul (get_local $f1_2) (get_local $f9_38)))
|
|
(set_local $f2f2 (i64.mul (get_local $f2) (get_local $f2)))
|
|
(set_local $f2f3_2 (i64.mul (get_local $f2_2) (get_local $f3)))
|
|
(set_local $f2f4_2 (i64.mul (get_local $f2_2) (get_local $f4)))
|
|
(set_local $f2f5_2 (i64.mul (get_local $f2_2) (get_local $f5)))
|
|
(set_local $f2f6_2 (i64.mul (get_local $f2_2) (get_local $f6)))
|
|
(set_local $f2f7_2 (i64.mul (get_local $f2_2) (get_local $f7)))
|
|
(set_local $f2f8_38 (i64.mul (get_local $f2_2) (get_local $f8_19)))
|
|
(set_local $f2f9_38 (i64.mul (get_local $f2) (get_local $f9_38)))
|
|
(set_local $f3f3_2 (i64.mul (get_local $f3_2) (get_local $f3)))
|
|
(set_local $f3f4_2 (i64.mul (get_local $f3_2) (get_local $f4)))
|
|
(set_local $f3f5_4 (i64.mul (get_local $f3_2) (get_local $f5_2)))
|
|
(set_local $f3f6_2 (i64.mul (get_local $f3_2) (get_local $f6)))
|
|
(set_local $f3f7_76 (i64.mul (get_local $f3_2) (get_local $f7_38)))
|
|
(set_local $f3f8_38 (i64.mul (get_local $f3_2) (get_local $f8_19)))
|
|
(set_local $f3f9_76 (i64.mul (get_local $f3_2) (get_local $f9_38)))
|
|
(set_local $f4f4 (i64.mul (get_local $f4) (get_local $f4)))
|
|
(set_local $f4f5_2 (i64.mul (get_local $f4_2) (get_local $f5)))
|
|
(set_local $f4f6_38 (i64.mul (get_local $f4_2) (get_local $f6_19)))
|
|
(set_local $f4f7_38 (i64.mul (get_local $f4) (get_local $f7_38)))
|
|
(set_local $f4f8_38 (i64.mul (get_local $f4_2) (get_local $f8_19)))
|
|
(set_local $f4f9_38 (i64.mul (get_local $f4) (get_local $f9_38)))
|
|
(set_local $f5f5_38 (i64.mul (get_local $f5) (get_local $f5_38)))
|
|
(set_local $f5f6_38 (i64.mul (get_local $f5_2) (get_local $f6_19)))
|
|
(set_local $f5f7_76 (i64.mul (get_local $f5_2) (get_local $f7_38)))
|
|
(set_local $f5f8_38 (i64.mul (get_local $f5_2) (get_local $f8_19)))
|
|
(set_local $f5f9_76 (i64.mul (get_local $f5_2) (get_local $f9_38)))
|
|
(set_local $f6f6_19 (i64.mul (get_local $f6) (get_local $f6_19)))
|
|
(set_local $f6f7_38 (i64.mul (get_local $f6) (get_local $f7_38)))
|
|
(set_local $f6f8_38 (i64.mul (get_local $f6_2) (get_local $f8_19)))
|
|
(set_local $f6f9_38 (i64.mul (get_local $f6) (get_local $f9_38)))
|
|
(set_local $f7f7_38 (i64.mul (get_local $f7) (get_local $f7_38)))
|
|
(set_local $f7f8_38 (i64.mul (get_local $f7_2) (get_local $f8_19)))
|
|
(set_local $f7f9_76 (i64.mul (get_local $f7_2) (get_local $f9_38)))
|
|
(set_local $f8f8_19 (i64.mul (get_local $f8) (get_local $f8_19)))
|
|
(set_local $f8f9_38 (i64.mul (get_local $f8) (get_local $f9_38)))
|
|
(set_local $f9f9_38 (i64.mul (get_local $f9) (get_local $f9_38)))
|
|
|
|
(set_local $h0 (i64.add (get_local $f0f0) (i64.add (get_local $f1f9_76) (i64.add (get_local $f2f8_38) (i64.add (get_local $f3f7_76) (i64.add (get_local $f4f6_38) (get_local $f5f5_38)))))))
|
|
(set_local $h1 (i64.add (get_local $f0f1_2) (i64.add (get_local $f2f9_38) (i64.add (get_local $f3f8_38) (i64.add (get_local $f4f7_38) (get_local $f5f6_38))))))
|
|
(set_local $h2 (i64.add (get_local $f0f2_2) (i64.add (get_local $f1f1_2) (i64.add (get_local $f3f9_76) (i64.add (get_local $f4f8_38) (i64.add (get_local $f5f7_76) (get_local $f6f6_19)))))))
|
|
(set_local $h3 (i64.add (get_local $f0f3_2) (i64.add (get_local $f1f2_2) (i64.add (get_local $f4f9_38) (i64.add (get_local $f5f8_38) (get_local $f6f7_38))))))
|
|
(set_local $h4 (i64.add (get_local $f0f4_2) (i64.add (get_local $f1f3_4) (i64.add (get_local $f2f2) (i64.add (get_local $f5f9_76) (i64.add (get_local $f6f8_38) (get_local $f7f7_38)))))))
|
|
(set_local $h5 (i64.add (get_local $f0f5_2) (i64.add (get_local $f1f4_2) (i64.add (get_local $f2f3_2) (i64.add (get_local $f6f9_38) (get_local $f7f8_38))))))
|
|
(set_local $h6 (i64.add (get_local $f0f6_2) (i64.add (get_local $f1f5_4) (i64.add (get_local $f2f4_2) (i64.add (get_local $f3f3_2) (i64.add (get_local $f7f9_76) (get_local $f8f8_19)))))))
|
|
(set_local $h7 (i64.add (get_local $f0f7_2) (i64.add (get_local $f1f6_2) (i64.add (get_local $f2f5_2) (i64.add (get_local $f3f4_2) (get_local $f8f9_38))))))
|
|
(set_local $h8 (i64.add (get_local $f0f8_2) (i64.add (get_local $f1f7_4) (i64.add (get_local $f2f6_2) (i64.add (get_local $f3f5_4) (i64.add (get_local $f4f4) (get_local $f9f9_38)))))))
|
|
(set_local $h9 (i64.add (get_local $f0f9_2) (i64.add (get_local $f1f8_2) (i64.add (get_local $f2f7_2) (i64.add (get_local $f3f6_2) (get_local $f4f5_2 ))))))
|
|
|
|
(if (i32.eq (get_local $double) (i32.const 1))
|
|
(then
|
|
(set_local $h0 (i64.add (get_local $h0) (get_local $h0)))
|
|
(set_local $h1 (i64.add (get_local $h1) (get_local $h1)))
|
|
(set_local $h2 (i64.add (get_local $h2) (get_local $h2)))
|
|
(set_local $h3 (i64.add (get_local $h3) (get_local $h3)))
|
|
(set_local $h4 (i64.add (get_local $h4) (get_local $h4)))
|
|
(set_local $h5 (i64.add (get_local $h5) (get_local $h5)))
|
|
(set_local $h6 (i64.add (get_local $h6) (get_local $h6)))
|
|
(set_local $h7 (i64.add (get_local $h7) (get_local $h7)))
|
|
(set_local $h8 (i64.add (get_local $h8) (get_local $h8)))
|
|
(set_local $h9 (i64.add (get_local $h9) (get_local $h9)))))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $h0) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h1 (i64.add (get_local $h1) (get_local $carry0)))
|
|
(set_local $h0 (i64.sub (get_local $h0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $h4) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h5 (i64.add (get_local $h5) (get_local $carry4)))
|
|
(set_local $h4 (i64.sub (get_local $h4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (i64.add (get_local $h1) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h2 (i64.add (get_local $h2) (get_local $carry1)))
|
|
(set_local $h1 (i64.sub (get_local $h1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
(set_local $carry5 (i64.shr_s (i64.add (get_local $h5) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h6 (i64.add (get_local $h6) (get_local $carry5)))
|
|
(set_local $h5 (i64.sub (get_local $h5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (i64.add (get_local $h2) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h3 (i64.add (get_local $h3) (get_local $carry2)))
|
|
(set_local $h2 (i64.sub (get_local $h2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $h6) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h7 (i64.add (get_local $h7) (get_local $carry6)))
|
|
(set_local $h6 (i64.sub (get_local $h6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (i64.add (get_local $h3) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h4 (i64.add (get_local $h4) (get_local $carry3)))
|
|
(set_local $h3 (i64.sub (get_local $h3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $h7) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h8 (i64.add (get_local $h8) (get_local $carry7)))
|
|
(set_local $h7 (i64.sub (get_local $h7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $h4) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h5 (i64.add (get_local $h5) (get_local $carry4)))
|
|
(set_local $h4 (i64.sub (get_local $h4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $h8) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h9 (i64.add (get_local $h9) (get_local $carry8)))
|
|
(set_local $h8 (i64.sub (get_local $h8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $h9) (i64.shl (i64.const 1) (i64.const 24))) (i64.const 25)))
|
|
(set_local $h0 (i64.add (get_local $h0) (i64.mul (get_local $carry9) (i64.const 19))))
|
|
(set_local $h9 (i64.sub (get_local $h9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 25)))))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $h0) (i64.shl (i64.const 1) (i64.const 25))) (i64.const 26)))
|
|
(set_local $h1 (i64.add (get_local $h1) (get_local $carry0)))
|
|
(set_local $h0 (i64.sub (get_local $h0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 26)))))
|
|
|
|
(i64.store32 offset=0 (get_local $h) (get_local $h0))
|
|
(i64.store32 offset=4 (get_local $h) (get_local $h1))
|
|
(i64.store32 offset=8 (get_local $h) (get_local $h2))
|
|
(i64.store32 offset=12 (get_local $h) (get_local $h3))
|
|
(i64.store32 offset=16 (get_local $h) (get_local $h4))
|
|
(i64.store32 offset=20 (get_local $h) (get_local $h5))
|
|
(i64.store32 offset=24 (get_local $h) (get_local $h6))
|
|
(i64.store32 offset=28 (get_local $h) (get_local $h7))
|
|
(i64.store32 offset=32 (get_local $h) (get_local $h8))
|
|
(i64.store32 offset=36 (get_local $h) (get_local $h9))
|
|
)
|
|
|
|
|
|
(func $sc25519_mul (export "sc25519_mul") (param $s i32) (param $a i32) (param $b i32)
|
|
(local $tmp i64)
|
|
|
|
(local $a0 i64)
|
|
(local $a1 i64)
|
|
(local $a2 i64)
|
|
(local $a3 i64)
|
|
(local $a4 i64)
|
|
(local $a5 i64)
|
|
(local $a6 i64)
|
|
(local $a7 i64)
|
|
(local $a8 i64)
|
|
(local $a9 i64)
|
|
(local $a10 i64)
|
|
(local $a11 i64)
|
|
|
|
(local $b0 i64)
|
|
(local $b1 i64)
|
|
(local $b2 i64)
|
|
(local $b3 i64)
|
|
(local $b4 i64)
|
|
(local $b5 i64)
|
|
(local $b6 i64)
|
|
(local $b7 i64)
|
|
(local $b8 i64)
|
|
(local $b9 i64)
|
|
(local $b10 i64)
|
|
(local $b11 i64)
|
|
|
|
(local $s0 i64)
|
|
(local $s1 i64)
|
|
(local $s2 i64)
|
|
(local $s3 i64)
|
|
(local $s4 i64)
|
|
(local $s5 i64)
|
|
(local $s6 i64)
|
|
(local $s7 i64)
|
|
(local $s8 i64)
|
|
(local $s9 i64)
|
|
(local $s10 i64)
|
|
(local $s11 i64)
|
|
(local $s12 i64)
|
|
(local $s13 i64)
|
|
(local $s14 i64)
|
|
(local $s15 i64)
|
|
(local $s16 i64)
|
|
(local $s17 i64)
|
|
(local $s18 i64)
|
|
(local $s19 i64)
|
|
(local $s20 i64)
|
|
(local $s21 i64)
|
|
(local $s22 i64)
|
|
(local $s23 i64)
|
|
|
|
(local $carry0 i64)
|
|
(local $carry1 i64)
|
|
(local $carry2 i64)
|
|
(local $carry3 i64)
|
|
(local $carry4 i64)
|
|
(local $carry5 i64)
|
|
(local $carry6 i64)
|
|
(local $carry7 i64)
|
|
(local $carry8 i64)
|
|
(local $carry9 i64)
|
|
(local $carry10 i64)
|
|
(local $carry11 i64)
|
|
(local $carry12 i64)
|
|
(local $carry13 i64)
|
|
(local $carry14 i64)
|
|
(local $carry15 i64)
|
|
(local $carry16 i64)
|
|
(local $carry17 i64)
|
|
(local $carry18 i64)
|
|
(local $carry19 i64)
|
|
(local $carry20 i64)
|
|
(local $carry21 i64)
|
|
(local $carry22 i64)
|
|
|
|
(set_local $a0 (i64.load32_u offset=0 (get_local $a)))
|
|
(set_local $a1 (i64.load32_u offset=4 (get_local $a)))
|
|
(set_local $a2 (i64.load32_u offset=8 (get_local $a)))
|
|
(set_local $a3 (i64.load32_u offset=12 (get_local $a)))
|
|
(set_local $a4 (i64.load32_u offset=16 (get_local $a)))
|
|
(set_local $a5 (i64.load32_u offset=20 (get_local $a)))
|
|
(set_local $a6 (i64.load32_u offset=24 (get_local $a)))
|
|
(set_local $a7 (i64.load32_u offset=28 (get_local $a)))
|
|
(set_local $a8 (i64.load32_u offset=32 (get_local $a)))
|
|
(set_local $a9 (i64.load32_u offset=36 (get_local $a)))
|
|
(set_local $a10 (i64.load32_u offset=40 (get_local $a)))
|
|
(set_local $a11 (i64.load32_u offset=44 (get_local $a)))
|
|
|
|
(set_local $b0 (i64.load32_u offset=0 (get_local $b)))
|
|
(set_local $b1 (i64.load32_u offset=4 (get_local $b)))
|
|
(set_local $b2 (i64.load32_u offset=8 (get_local $b)))
|
|
(set_local $b3 (i64.load32_u offset=12 (get_local $b)))
|
|
(set_local $b4 (i64.load32_u offset=16 (get_local $b)))
|
|
(set_local $b5 (i64.load32_u offset=20 (get_local $b)))
|
|
(set_local $b6 (i64.load32_u offset=24 (get_local $b)))
|
|
(set_local $b7 (i64.load32_u offset=28 (get_local $b)))
|
|
(set_local $b8 (i64.load32_u offset=32 (get_local $b)))
|
|
(set_local $b9 (i64.load32_u offset=36 (get_local $b)))
|
|
(set_local $b10 (i64.load32_u offset=40 (get_local $b)))
|
|
(set_local $b11 (i64.load32_u offset=44 (get_local $b)))
|
|
|
|
(call $extend_sign (get_local $a0))
|
|
(set_local $a0)
|
|
(call $extend_sign (get_local $a1))
|
|
(set_local $a1)
|
|
(call $extend_sign (get_local $a2))
|
|
(set_local $a2)
|
|
(call $extend_sign (get_local $a3))
|
|
(set_local $a3)
|
|
(call $extend_sign (get_local $a4))
|
|
(set_local $a4)
|
|
(call $extend_sign (get_local $a5))
|
|
(set_local $a5)
|
|
(call $extend_sign (get_local $a6))
|
|
(set_local $a6)
|
|
(call $extend_sign (get_local $a7))
|
|
(set_local $a7)
|
|
(call $extend_sign (get_local $a8))
|
|
(set_local $a8)
|
|
(call $extend_sign (get_local $a9))
|
|
(set_local $a9)
|
|
(call $extend_sign (get_local $a10))
|
|
(set_local $a10)
|
|
(call $extend_sign (get_local $a11))
|
|
(set_local $a11)
|
|
|
|
(call $extend_sign (get_local $b0))
|
|
(set_local $b0)
|
|
(call $extend_sign (get_local $b1))
|
|
(set_local $b1)
|
|
(call $extend_sign (get_local $b2))
|
|
(set_local $b2)
|
|
(call $extend_sign (get_local $b3))
|
|
(set_local $b3)
|
|
(call $extend_sign (get_local $b4))
|
|
(set_local $b4)
|
|
(call $extend_sign (get_local $b5))
|
|
(set_local $b5)
|
|
(call $extend_sign (get_local $b6))
|
|
(set_local $b6)
|
|
(call $extend_sign (get_local $b7))
|
|
(set_local $b7)
|
|
(call $extend_sign (get_local $b8))
|
|
(set_local $b8)
|
|
(call $extend_sign (get_local $b9))
|
|
(set_local $b9)
|
|
(call $extend_sign (get_local $b10))
|
|
(set_local $b10)
|
|
(call $extend_sign (get_local $b11))
|
|
(set_local $b11)
|
|
|
|
(set_local $s0 (i64.mul (get_local $a0) (get_local $b0)))
|
|
(set_local $s1 (i64.add (i64.mul (get_local $a0) (get_local $b1 )) (i64.mul (get_local $a1) (get_local $b0))))
|
|
(set_local $s2 (i64.add (i64.mul (get_local $a0) (get_local $b2 )) (i64.add (i64.mul (get_local $a1) (get_local $b1 )) (i64.mul (get_local $a2) (get_local $b0)))))
|
|
(set_local $s3 (i64.add (i64.mul (get_local $a0) (get_local $b3 )) (i64.add (i64.mul (get_local $a1) (get_local $b2 )) (i64.add (i64.mul (get_local $a2) (get_local $b1)) (i64.mul (get_local $a3) (get_local $b0))))))
|
|
(set_local $s4 (i64.add (i64.mul (get_local $a0) (get_local $b4 )) (i64.add (i64.mul (get_local $a1) (get_local $b3 )) (i64.add (i64.mul (get_local $a2) (get_local $b2)) (i64.add (i64.mul (get_local $a3) (get_local $b1)) (i64.mul (get_local $a4) (get_local $b0)))))))
|
|
(set_local $s5 (i64.add (i64.mul (get_local $a0) (get_local $b5 )) (i64.add (i64.mul (get_local $a1) (get_local $b4 )) (i64.add (i64.mul (get_local $a2) (get_local $b3)) (i64.add (i64.mul (get_local $a3) (get_local $b2)) (i64.add (i64.mul (get_local $a4) (get_local $b1)) (i64.mul (get_local $a5) (get_local $b0))))))))
|
|
(set_local $s6 (i64.add (i64.mul (get_local $a0) (get_local $b6 )) (i64.add (i64.mul (get_local $a1) (get_local $b5 )) (i64.add (i64.mul (get_local $a2) (get_local $b4)) (i64.add (i64.mul (get_local $a3) (get_local $b3)) (i64.add (i64.mul (get_local $a4) (get_local $b2)) (i64.add (i64.mul (get_local $a5) (get_local $b1)) (i64.mul (get_local $a6) (get_local $b0)))))))))
|
|
(set_local $s7 (i64.add (i64.mul (get_local $a0) (get_local $b7 )) (i64.add (i64.mul (get_local $a1) (get_local $b6 )) (i64.add (i64.mul (get_local $a2) (get_local $b5)) (i64.add (i64.mul (get_local $a3) (get_local $b4)) (i64.add (i64.mul (get_local $a4) (get_local $b3)) (i64.add (i64.mul (get_local $a5) (get_local $b2)) (i64.add (i64.mul (get_local $a6) (get_local $b1)) (i64.mul (get_local $a7) (get_local $b0))))))))))
|
|
(set_local $s8 (i64.add (i64.mul (get_local $a0) (get_local $b8 )) (i64.add (i64.mul (get_local $a1) (get_local $b7 )) (i64.add (i64.mul (get_local $a2) (get_local $b6)) (i64.add (i64.mul (get_local $a3) (get_local $b5)) (i64.add (i64.mul (get_local $a4) (get_local $b4)) (i64.add (i64.mul (get_local $a5) (get_local $b3)) (i64.add (i64.mul (get_local $a6) (get_local $b2)) (i64.add (i64.mul (get_local $a7) (get_local $b1)) (i64.mul (get_local $a8) (get_local $b0)))))))))))
|
|
(set_local $s9 (i64.add (i64.mul (get_local $a0) (get_local $b9 )) (i64.add (i64.mul (get_local $a1) (get_local $b8 )) (i64.add (i64.mul (get_local $a2) (get_local $b7)) (i64.add (i64.mul (get_local $a3) (get_local $b6)) (i64.add (i64.mul (get_local $a4) (get_local $b5)) (i64.add (i64.mul (get_local $a5) (get_local $b4)) (i64.add (i64.mul (get_local $a6) (get_local $b3)) (i64.add (i64.mul (get_local $a7) (get_local $b2)) (i64.add (i64.mul (get_local $a8) (get_local $b1)) (i64.mul (get_local $a9) (get_local $b0))))))))))))
|
|
(set_local $s10 (i64.add (i64.mul (get_local $a0) (get_local $b10)) (i64.add (i64.mul (get_local $a1) (get_local $b9 )) (i64.add (i64.mul (get_local $a2) (get_local $b8)) (i64.add (i64.mul (get_local $a3) (get_local $b7)) (i64.add (i64.mul (get_local $a4) (get_local $b6)) (i64.add (i64.mul (get_local $a5) (get_local $b5)) (i64.add (i64.mul (get_local $a6) (get_local $b4)) (i64.add (i64.mul (get_local $a7) (get_local $b3)) (i64.add (i64.mul (get_local $a8) (get_local $b2)) (i64.add (i64.mul (get_local $a9) (get_local $b1)) (i64.mul (get_local $a10) (get_local $b0)))))))))))))
|
|
(set_local $s11 (i64.add (i64.mul (get_local $a0) (get_local $b11)) (i64.add (i64.mul (get_local $a1) (get_local $b10)) (i64.add (i64.mul (get_local $a2) (get_local $b9)) (i64.add (i64.mul (get_local $a3) (get_local $b8)) (i64.add (i64.mul (get_local $a4) (get_local $b7)) (i64.add (i64.mul (get_local $a5) (get_local $b6)) (i64.add (i64.mul (get_local $a6) (get_local $b5)) (i64.add (i64.mul (get_local $a7) (get_local $b4)) (i64.add (i64.mul (get_local $a8) (get_local $b3)) (i64.add (i64.mul (get_local $a9) (get_local $b2)) (i64.add (i64.mul (get_local $a10) (get_local $b1)) (i64.mul (get_local $a11) (get_local $b0))))))))))))))
|
|
(set_local $s12 (i64.add (i64.mul (get_local $a1) (get_local $b11)) (i64.add (i64.mul (get_local $a2) (get_local $b10)) (i64.add (i64.mul (get_local $a3) (get_local $b9)) (i64.add (i64.mul (get_local $a4) (get_local $b8)) (i64.add (i64.mul (get_local $a5) (get_local $b7)) (i64.add (i64.mul (get_local $a6) (get_local $b6)) (i64.add (i64.mul (get_local $a7) (get_local $b5)) (i64.add (i64.mul (get_local $a8) (get_local $b4)) (i64.add (i64.mul (get_local $a9) (get_local $b3)) (i64.add (i64.mul (get_local $a10) (get_local $b2)) (i64.mul (get_local $a11) (get_local $b1)))))))))))))
|
|
(set_local $s13 (i64.add (i64.mul (get_local $a2) (get_local $b11)) (i64.add (i64.mul (get_local $a3) (get_local $b10)) (i64.add (i64.mul (get_local $a4) (get_local $b9)) (i64.add (i64.mul (get_local $a5) (get_local $b8)) (i64.add (i64.mul (get_local $a6) (get_local $b7)) (i64.add (i64.mul (get_local $a7) (get_local $b6)) (i64.add (i64.mul (get_local $a8) (get_local $b5)) (i64.add (i64.mul (get_local $a9) (get_local $b4)) (i64.add (i64.mul (get_local $a10) (get_local $b3)) (i64.mul (get_local $a11) (get_local $b2))))))))))))
|
|
(set_local $s14 (i64.add (i64.mul (get_local $a3) (get_local $b11)) (i64.add (i64.mul (get_local $a4) (get_local $b10)) (i64.add (i64.mul (get_local $a5) (get_local $b9)) (i64.add (i64.mul (get_local $a6) (get_local $b8)) (i64.add (i64.mul (get_local $a7) (get_local $b7)) (i64.add (i64.mul (get_local $a8) (get_local $b6)) (i64.add (i64.mul (get_local $a9) (get_local $b5)) (i64.add (i64.mul (get_local $a10) (get_local $b4)) (i64.mul (get_local $a11) (get_local $b3)))))))))))
|
|
(set_local $s15 (i64.add (i64.mul (get_local $a4) (get_local $b11)) (i64.add (i64.mul (get_local $a5) (get_local $b10)) (i64.add (i64.mul (get_local $a6) (get_local $b9)) (i64.add (i64.mul (get_local $a7) (get_local $b8)) (i64.add (i64.mul (get_local $a8) (get_local $b7)) (i64.add (i64.mul (get_local $a9) (get_local $b6)) (i64.add (i64.mul (get_local $a10) (get_local $b5)) (i64.mul (get_local $a11) (get_local $b4))))))))))
|
|
(set_local $s16 (i64.add (i64.mul (get_local $a5) (get_local $b11)) (i64.add (i64.mul (get_local $a6) (get_local $b10)) (i64.add (i64.mul (get_local $a7) (get_local $b9)) (i64.add (i64.mul (get_local $a8) (get_local $b8)) (i64.add (i64.mul (get_local $a9) (get_local $b7)) (i64.add (i64.mul (get_local $a10) (get_local $b6)) (i64.mul (get_local $a11) (get_local $b5)))))))))
|
|
(set_local $s17 (i64.add (i64.mul (get_local $a6) (get_local $b11)) (i64.add (i64.mul (get_local $a7) (get_local $b10)) (i64.add (i64.mul (get_local $a8) (get_local $b9)) (i64.add (i64.mul (get_local $a9) (get_local $b8)) (i64.add (i64.mul (get_local $a10) (get_local $b7)) (i64.mul (get_local $a11) (get_local $b6))))))))
|
|
(set_local $s18 (i64.add (i64.mul (get_local $a7) (get_local $b11)) (i64.add (i64.mul (get_local $a8) (get_local $b10)) (i64.add (i64.mul (get_local $a9) (get_local $b9)) (i64.add (i64.mul (get_local $a10) (get_local $b8)) (i64.mul (get_local $a11) (get_local $b7)))))))
|
|
(set_local $s19 (i64.add (i64.mul (get_local $a8) (get_local $b11)) (i64.add (i64.mul (get_local $a9) (get_local $b10)) (i64.add (i64.mul (get_local $a10) (get_local $b9)) (i64.mul (get_local $a11) (get_local $b8))))))
|
|
(set_local $s20 (i64.add (i64.mul (get_local $a9) (get_local $b11)) (i64.add (i64.mul (get_local $a10) (get_local $b10)) (i64.mul (get_local $a11) (get_local $b9)))))
|
|
(set_local $s21 (i64.add (i64.mul (get_local $a10) (get_local $b11)) (i64.mul (get_local $a11) (get_local $b10))))
|
|
(set_local $s22 (i64.mul (get_local $a11) (get_local $b11)))
|
|
(set_local $s23 (i64.const 0))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $s0) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (i64.add (get_local $s2) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $s4) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $s6) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $s8) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (i64.add (get_local $s10) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry12 (i64.shr_s (i64.add (get_local $s12) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s13 (i64.add (get_local $s13) (get_local $carry12)))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $carry12) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry14 (i64.shr_s (i64.add (get_local $s14) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s15 (i64.add (get_local $s15) (get_local $carry14)))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $carry14) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry16 (i64.shr_s (i64.add (get_local $s16) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s17 (i64.add (get_local $s17) (get_local $carry16)))
|
|
(set_local $s16 (i64.sub (get_local $s16) (i64.mul (get_local $carry16) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry18 (i64.shr_s (i64.add (get_local $s18) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s19 (i64.add (get_local $s19) (get_local $carry18)))
|
|
(set_local $s18 (i64.sub (get_local $s18) (i64.mul (get_local $carry18) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry20 (i64.shr_s (i64.add (get_local $s20) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s21 (i64.add (get_local $s21) (get_local $carry20)))
|
|
(set_local $s20 (i64.sub (get_local $s20) (i64.mul (get_local $carry20) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry22 (i64.shr_s (i64.add (get_local $s22) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s23 (i64.add (get_local $s23) (get_local $carry22)))
|
|
(set_local $s22 (i64.sub (get_local $s22) (i64.mul (get_local $carry22) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (i64.add (get_local $s1) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (i64.add (get_local $s3) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (i64.add (get_local $s5) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $s7) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $s9) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (i64.add (get_local $s11) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry13 (i64.shr_s (i64.add (get_local $s13) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s14 (i64.add (get_local $s14) (get_local $carry13)))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $carry13) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry15 (i64.shr_s (i64.add (get_local $s15) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s16 (i64.add (get_local $s16) (get_local $carry15)))
|
|
(set_local $s15 (i64.sub (get_local $s15) (i64.mul (get_local $carry15) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry17 (i64.shr_s (i64.add (get_local $s17) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s18 (i64.add (get_local $s18) (get_local $carry17)))
|
|
(set_local $s17 (i64.sub (get_local $s17) (i64.mul (get_local $carry17) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry19 (i64.shr_s (i64.add (get_local $s19) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s20 (i64.add (get_local $s20) (get_local $carry19)))
|
|
(set_local $s19 (i64.sub (get_local $s19) (i64.mul (get_local $carry19) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry21 (i64.shr_s (i64.add (get_local $s21) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s22 (i64.add (get_local $s22) (get_local $carry21)))
|
|
(set_local $s21 (i64.sub (get_local $s21) (i64.mul (get_local $carry21) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s23) (i64.const 666643))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s23) (i64.const 470296))))
|
|
(set_local $s13 (i64.add (get_local $s13) (i64.mul (get_local $s23) (i64.const 654183))))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $s23) (i64.const 997805))))
|
|
(set_local $s15 (i64.add (get_local $s15) (i64.mul (get_local $s23) (i64.const 136657))))
|
|
(set_local $s16 (i64.sub (get_local $s16) (i64.mul (get_local $s23) (i64.const 683901))))
|
|
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s22) (i64.const 666643))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s22) (i64.const 470296))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s22) (i64.const 654183))))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $s22) (i64.const 997805))))
|
|
(set_local $s14 (i64.add (get_local $s14) (i64.mul (get_local $s22) (i64.const 136657))))
|
|
(set_local $s15 (i64.sub (get_local $s15) (i64.mul (get_local $s22) (i64.const 683901))))
|
|
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s21) (i64.const 666643))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s21) (i64.const 470296))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s21) (i64.const 654183))))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $s21) (i64.const 997805))))
|
|
(set_local $s13 (i64.add (get_local $s13) (i64.mul (get_local $s21) (i64.const 136657))))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $s21) (i64.const 683901))))
|
|
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s20) (i64.const 666643))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s20) (i64.const 470296))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s20) (i64.const 654183))))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $s20) (i64.const 997805))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s20) (i64.const 136657))))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $s20) (i64.const 683901))))
|
|
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s19) (i64.const 666643))))
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s19) (i64.const 470296))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s19) (i64.const 654183))))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $s19) (i64.const 997805))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s19) (i64.const 136657))))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $s19) (i64.const 683901))))
|
|
|
|
(set_local $s6 (i64.add (get_local $s6 ) (i64.mul (get_local $s18) (i64.const 666643))))
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s18) (i64.const 470296))))
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s18) (i64.const 654183))))
|
|
(set_local $s9 (i64.sub (get_local $s9 ) (i64.mul (get_local $s18) (i64.const 997805))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s18) (i64.const 136657))))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $s18) (i64.const 683901))))
|
|
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $s6) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $s8) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (i64.add (get_local $s10) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry12 (i64.shr_s (i64.add (get_local $s12) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s13 (i64.add (get_local $s13) (get_local $carry12)))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $carry12) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry14 (i64.shr_s (i64.add (get_local $s14) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s15 (i64.add (get_local $s15) (get_local $carry14)))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $carry14) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry16 (i64.shr_s (i64.add (get_local $s16) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s17 (i64.add (get_local $s17) (get_local $carry16)))
|
|
(set_local $s16 (i64.sub (get_local $s16) (i64.mul (get_local $carry16) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $s7) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $s9) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (i64.add (get_local $s11) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry13 (i64.shr_s (i64.add (get_local $s13) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s14 (i64.add (get_local $s14) (get_local $carry13)))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $carry13) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry15 (i64.shr_s (i64.add (get_local $s15) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s16 (i64.add (get_local $s16) (get_local $carry15)))
|
|
(set_local $s15 (i64.sub (get_local $s15) (i64.mul (get_local $carry15) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s5 (i64.add (get_local $s5 ) (i64.mul (get_local $s17) (i64.const 666643))))
|
|
(set_local $s6 (i64.add (get_local $s6 ) (i64.mul (get_local $s17) (i64.const 470296))))
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s17) (i64.const 654183))))
|
|
(set_local $s8 (i64.sub (get_local $s8 ) (i64.mul (get_local $s17) (i64.const 997805))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s17) (i64.const 136657))))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $s17) (i64.const 683901))))
|
|
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s16) (i64.const 666643))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s16) (i64.const 470296))))
|
|
(set_local $s6 (i64.add (get_local $s6) (i64.mul (get_local $s16) (i64.const 654183))))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $s16) (i64.const 997805))))
|
|
(set_local $s8 (i64.add (get_local $s8) (i64.mul (get_local $s16) (i64.const 136657))))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $s16) (i64.const 683901))))
|
|
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s15) (i64.const 666643))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s15) (i64.const 470296))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s15) (i64.const 654183))))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $s15) (i64.const 997805))))
|
|
(set_local $s7 (i64.add (get_local $s7) (i64.mul (get_local $s15) (i64.const 136657))))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $s15) (i64.const 683901))))
|
|
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s14) (i64.const 666643))))
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s14) (i64.const 470296))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s14) (i64.const 654183))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s14) (i64.const 997805))))
|
|
(set_local $s6 (i64.add (get_local $s6) (i64.mul (get_local $s14) (i64.const 136657))))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $s14) (i64.const 683901))))
|
|
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s13) (i64.const 666643))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s13) (i64.const 470296))))
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s13) (i64.const 654183))))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $s13) (i64.const 997805))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s13) (i64.const 136657))))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $s13) (i64.const 683901))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
(set_local $s12 (i64.const 0))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $s0) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (i64.add (get_local $s2) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $s4) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $s6) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $s8) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (i64.add (get_local $s10) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (i64.add (get_local $s1) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (i64.add (get_local $s3) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (i64.add (get_local $s5) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $s7) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $s9) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (i64.add (get_local $s11) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
(set_local $s12 (i64.const 0))
|
|
|
|
(set_local $carry0 (i64.shr_s (get_local $s0) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (get_local $s1) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (get_local $s2) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (get_local $s3) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (get_local $s4) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (get_local $s5) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (get_local $s6) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (get_local $s7) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (get_local $s8) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (get_local $s9) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (get_local $s10) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (get_local $s11) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
|
|
(set_local $carry0 (i64.shr_s (get_local $s0) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (get_local $s1) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (get_local $s2) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (get_local $s3) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (get_local $s4) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (get_local $s5) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (get_local $s6) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (get_local $s7) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (get_local $s8) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (get_local $s9) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (get_local $s10) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (get_local $s0) (i64.const 0xff))
|
|
(i64.and (get_local $s0) (i64.const 0xff00))
|
|
(i64.or)
|
|
(get_local $s0)
|
|
(i64.shl (i64.mul (get_local $s1) (i64.const 32)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.shl (i64.mul (get_local $s2) (i64.const 4)) (i64.const 40))
|
|
(i64.or)
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s2) (i64.const 42))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s2) (i64.const 42))
|
|
(i64.shl (i64.mul (get_local $s3) (i64.const 128)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=0)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s3) (i64.const 1)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s3) (i64.const 1)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s3) (i64.const 1))
|
|
(i64.shl (i64.mul (get_local $s4) (i64.const 16)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.shl (i64.mul (get_local $s5) (i64.const 2)) (i64.const 40))
|
|
(i64.or)
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s5) (i64.const 41))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s5) (i64.const 41))
|
|
(i64.shl (i64.mul (get_local $s6) (i64.const 64)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=8)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s6) (i64.const 2)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s6) (i64.const 2)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s6) (i64.const 2))
|
|
(i64.shl (i64.mul (get_local $s7) (i64.const 8)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s7) (i64.const 19))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s7) (i64.const 19))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.shl (i64.mul (get_local $s9) (i64.const 32)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=16)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s9) (i64.const 3)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s9) (i64.const 3)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s9) (i64.const 3))
|
|
(i64.shl (i64.mul (get_local $s10) (i64.const 4)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s10) (i64.const 18))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s10) (i64.const 18))
|
|
(i64.shl (i64.mul (get_local $s11) (i64.const 128)) (i64.const 32))
|
|
(i64.or)
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=24))
|
|
|
|
(func $sc25519_muladd (export "sc25519_muladd") (param $s i32) (param $a i32) (param $b i32) (param $c i32)
|
|
(local $tmp i64)
|
|
|
|
(local $a0 i64)
|
|
(local $a1 i64)
|
|
(local $a2 i64)
|
|
(local $a3 i64)
|
|
(local $a4 i64)
|
|
(local $a5 i64)
|
|
(local $a6 i64)
|
|
(local $a7 i64)
|
|
(local $a8 i64)
|
|
(local $a9 i64)
|
|
(local $a10 i64)
|
|
(local $a11 i64)
|
|
|
|
(local $b0 i64)
|
|
(local $b1 i64)
|
|
(local $b2 i64)
|
|
(local $b3 i64)
|
|
(local $b4 i64)
|
|
(local $b5 i64)
|
|
(local $b6 i64)
|
|
(local $b7 i64)
|
|
(local $b8 i64)
|
|
(local $b9 i64)
|
|
(local $b10 i64)
|
|
(local $b11 i64)
|
|
|
|
(local $c0 i64)
|
|
(local $c1 i64)
|
|
(local $c2 i64)
|
|
(local $c3 i64)
|
|
(local $c4 i64)
|
|
(local $c5 i64)
|
|
(local $c6 i64)
|
|
(local $c7 i64)
|
|
(local $c8 i64)
|
|
(local $c9 i64)
|
|
(local $c10 i64)
|
|
(local $c11 i64)
|
|
|
|
(local $s0 i64)
|
|
(local $s1 i64)
|
|
(local $s2 i64)
|
|
(local $s3 i64)
|
|
(local $s4 i64)
|
|
(local $s5 i64)
|
|
(local $s6 i64)
|
|
(local $s7 i64)
|
|
(local $s8 i64)
|
|
(local $s9 i64)
|
|
(local $s10 i64)
|
|
(local $s11 i64)
|
|
(local $s12 i64)
|
|
(local $s13 i64)
|
|
(local $s14 i64)
|
|
(local $s15 i64)
|
|
(local $s16 i64)
|
|
(local $s17 i64)
|
|
(local $s18 i64)
|
|
(local $s19 i64)
|
|
(local $s20 i64)
|
|
(local $s21 i64)
|
|
(local $s22 i64)
|
|
(local $s23 i64)
|
|
|
|
(local $carry0 i64)
|
|
(local $carry1 i64)
|
|
(local $carry2 i64)
|
|
(local $carry3 i64)
|
|
(local $carry4 i64)
|
|
(local $carry5 i64)
|
|
(local $carry6 i64)
|
|
(local $carry7 i64)
|
|
(local $carry8 i64)
|
|
(local $carry9 i64)
|
|
(local $carry10 i64)
|
|
(local $carry11 i64)
|
|
(local $carry12 i64)
|
|
(local $carry13 i64)
|
|
(local $carry14 i64)
|
|
(local $carry15 i64)
|
|
(local $carry16 i64)
|
|
(local $carry17 i64)
|
|
(local $carry18 i64)
|
|
(local $carry19 i64)
|
|
(local $carry20 i64)
|
|
(local $carry21 i64)
|
|
(local $carry22 i64)
|
|
|
|
(set_local $a0 (i64.load32_u offset=0 (get_local $a)))
|
|
(set_local $a1 (i64.load32_u offset=4 (get_local $a)))
|
|
(set_local $a2 (i64.load32_u offset=8 (get_local $a)))
|
|
(set_local $a3 (i64.load32_u offset=12 (get_local $a)))
|
|
(set_local $a4 (i64.load32_u offset=16 (get_local $a)))
|
|
(set_local $a5 (i64.load32_u offset=20 (get_local $a)))
|
|
(set_local $a6 (i64.load32_u offset=24 (get_local $a)))
|
|
(set_local $a7 (i64.load32_u offset=28 (get_local $a)))
|
|
(set_local $a8 (i64.load32_u offset=32 (get_local $a)))
|
|
(set_local $a9 (i64.load32_u offset=36 (get_local $a)))
|
|
(set_local $a10 (i64.load32_u offset=40 (get_local $a)))
|
|
(set_local $a11 (i64.load32_u offset=44 (get_local $a)))
|
|
|
|
(set_local $b0 (i64.load32_u offset=0 (get_local $b)))
|
|
(set_local $b1 (i64.load32_u offset=4 (get_local $b)))
|
|
(set_local $b2 (i64.load32_u offset=8 (get_local $b)))
|
|
(set_local $b3 (i64.load32_u offset=12 (get_local $b)))
|
|
(set_local $b4 (i64.load32_u offset=16 (get_local $b)))
|
|
(set_local $b5 (i64.load32_u offset=20 (get_local $b)))
|
|
(set_local $b6 (i64.load32_u offset=24 (get_local $b)))
|
|
(set_local $b7 (i64.load32_u offset=28 (get_local $b)))
|
|
(set_local $b8 (i64.load32_u offset=32 (get_local $b)))
|
|
(set_local $b9 (i64.load32_u offset=36 (get_local $b)))
|
|
(set_local $b10 (i64.load32_u offset=40 (get_local $b)))
|
|
(set_local $b11 (i64.load32_u offset=44 (get_local $b)))
|
|
|
|
(set_local $c0 (i64.load32_u offset=0 (get_local $c)))
|
|
(set_local $c1 (i64.load32_u offset=4 (get_local $c)))
|
|
(set_local $c2 (i64.load32_u offset=8 (get_local $c)))
|
|
(set_local $c3 (i64.load32_u offset=12 (get_local $c)))
|
|
(set_local $c4 (i64.load32_u offset=16 (get_local $c)))
|
|
(set_local $c5 (i64.load32_u offset=20 (get_local $c)))
|
|
(set_local $c6 (i64.load32_u offset=24 (get_local $c)))
|
|
(set_local $c7 (i64.load32_u offset=28 (get_local $c)))
|
|
(set_local $c8 (i64.load32_u offset=32 (get_local $c)))
|
|
(set_local $c9 (i64.load32_u offset=36 (get_local $c)))
|
|
(set_local $c10 (i64.load32_u offset=40 (get_local $c)))
|
|
(set_local $c11 (i64.load32_u offset=44 (get_local $c)))
|
|
|
|
(call $extend_sign (get_local $a0))
|
|
(set_local $a0)
|
|
(call $extend_sign (get_local $a1))
|
|
(set_local $a1)
|
|
(call $extend_sign (get_local $a2))
|
|
(set_local $a2)
|
|
(call $extend_sign (get_local $a3))
|
|
(set_local $a3)
|
|
(call $extend_sign (get_local $a4))
|
|
(set_local $a4)
|
|
(call $extend_sign (get_local $a5))
|
|
(set_local $a5)
|
|
(call $extend_sign (get_local $a6))
|
|
(set_local $a6)
|
|
(call $extend_sign (get_local $a7))
|
|
(set_local $a7)
|
|
(call $extend_sign (get_local $a8))
|
|
(set_local $a8)
|
|
(call $extend_sign (get_local $a9))
|
|
(set_local $a9)
|
|
(call $extend_sign (get_local $a10))
|
|
(set_local $a10)
|
|
(call $extend_sign (get_local $a11))
|
|
(set_local $a11)
|
|
|
|
(call $extend_sign (get_local $b0))
|
|
(set_local $b0)
|
|
(call $extend_sign (get_local $b1))
|
|
(set_local $b1)
|
|
(call $extend_sign (get_local $b2))
|
|
(set_local $b2)
|
|
(call $extend_sign (get_local $b3))
|
|
(set_local $b3)
|
|
(call $extend_sign (get_local $b4))
|
|
(set_local $b4)
|
|
(call $extend_sign (get_local $b5))
|
|
(set_local $b5)
|
|
(call $extend_sign (get_local $b6))
|
|
(set_local $b6)
|
|
(call $extend_sign (get_local $b7))
|
|
(set_local $b7)
|
|
(call $extend_sign (get_local $b8))
|
|
(set_local $b8)
|
|
(call $extend_sign (get_local $b9))
|
|
(set_local $b9)
|
|
(call $extend_sign (get_local $b10))
|
|
(set_local $b10)
|
|
(call $extend_sign (get_local $b11))
|
|
(set_local $b11)
|
|
|
|
(call $extend_sign (get_local $c0))
|
|
(set_local $c0)
|
|
(call $extend_sign (get_local $c1))
|
|
(set_local $c1)
|
|
(call $extend_sign (get_local $c2))
|
|
(set_local $c2)
|
|
(call $extend_sign (get_local $c3))
|
|
(set_local $c3)
|
|
(call $extend_sign (get_local $c4))
|
|
(set_local $c4)
|
|
(call $extend_sign (get_local $c5))
|
|
(set_local $c5)
|
|
(call $extend_sign (get_local $c6))
|
|
(set_local $c6)
|
|
(call $extend_sign (get_local $c7))
|
|
(set_local $c7)
|
|
(call $extend_sign (get_local $c8))
|
|
(set_local $c8)
|
|
(call $extend_sign (get_local $c9))
|
|
(set_local $c9)
|
|
(call $extend_sign (get_local $c10))
|
|
(set_local $c10)
|
|
(call $extend_sign (get_local $c11))
|
|
(set_local $c11)
|
|
|
|
(set_local $s0 (i64.add (get_local $c0 ) (i64.mul (get_local $a0) (get_local $b0))))
|
|
(set_local $s1 (i64.add (get_local $c1 ) (i64.add (i64.mul (get_local $a0) (get_local $b1 )) (i64.mul (get_local $a1) (get_local $b0)))))
|
|
(set_local $s2 (i64.add (get_local $c2 ) (i64.add (i64.mul (get_local $a0) (get_local $b2 )) (i64.add (i64.mul (get_local $a1) (get_local $b1 )) (i64.mul (get_local $a2) (get_local $b0))))))
|
|
(set_local $s3 (i64.add (get_local $c3 ) (i64.add (i64.mul (get_local $a0) (get_local $b3 )) (i64.add (i64.mul (get_local $a1) (get_local $b2 )) (i64.add (i64.mul (get_local $a2) (get_local $b1)) (i64.mul (get_local $a3) (get_local $b0)))))))
|
|
(set_local $s4 (i64.add (get_local $c4 ) (i64.add (i64.mul (get_local $a0) (get_local $b4 )) (i64.add (i64.mul (get_local $a1) (get_local $b3 )) (i64.add (i64.mul (get_local $a2) (get_local $b2)) (i64.add (i64.mul (get_local $a3) (get_local $b1)) (i64.mul (get_local $a4) (get_local $b0))))))))
|
|
(set_local $s5 (i64.add (get_local $c5 ) (i64.add (i64.mul (get_local $a0) (get_local $b5 )) (i64.add (i64.mul (get_local $a1) (get_local $b4 )) (i64.add (i64.mul (get_local $a2) (get_local $b3)) (i64.add (i64.mul (get_local $a3) (get_local $b2)) (i64.add (i64.mul (get_local $a4) (get_local $b1)) (i64.mul (get_local $a5) (get_local $b0)))))))))
|
|
(set_local $s6 (i64.add (get_local $c6 ) (i64.add (i64.mul (get_local $a0) (get_local $b6 )) (i64.add (i64.mul (get_local $a1) (get_local $b5 )) (i64.add (i64.mul (get_local $a2) (get_local $b4)) (i64.add (i64.mul (get_local $a3) (get_local $b3)) (i64.add (i64.mul (get_local $a4) (get_local $b2)) (i64.add (i64.mul (get_local $a5) (get_local $b1)) (i64.mul (get_local $a6) (get_local $b0))))))))))
|
|
(set_local $s7 (i64.add (get_local $c7 ) (i64.add (i64.mul (get_local $a0) (get_local $b7 )) (i64.add (i64.mul (get_local $a1) (get_local $b6 )) (i64.add (i64.mul (get_local $a2) (get_local $b5)) (i64.add (i64.mul (get_local $a3) (get_local $b4)) (i64.add (i64.mul (get_local $a4) (get_local $b3)) (i64.add (i64.mul (get_local $a5) (get_local $b2)) (i64.add (i64.mul (get_local $a6) (get_local $b1)) (i64.mul (get_local $a7) (get_local $b0)))))))))))
|
|
(set_local $s8 (i64.add (get_local $c8 ) (i64.add (i64.mul (get_local $a0) (get_local $b8 )) (i64.add (i64.mul (get_local $a1) (get_local $b7 )) (i64.add (i64.mul (get_local $a2) (get_local $b6)) (i64.add (i64.mul (get_local $a3) (get_local $b5)) (i64.add (i64.mul (get_local $a4) (get_local $b4)) (i64.add (i64.mul (get_local $a5) (get_local $b3)) (i64.add (i64.mul (get_local $a6) (get_local $b2)) (i64.add (i64.mul (get_local $a7) (get_local $b1)) (i64.mul (get_local $a8) (get_local $b0))))))))))))
|
|
(set_local $s9 (i64.add (get_local $c9 ) (i64.add (i64.mul (get_local $a0) (get_local $b9 )) (i64.add (i64.mul (get_local $a1) (get_local $b8 )) (i64.add (i64.mul (get_local $a2) (get_local $b7)) (i64.add (i64.mul (get_local $a3) (get_local $b6)) (i64.add (i64.mul (get_local $a4) (get_local $b5)) (i64.add (i64.mul (get_local $a5) (get_local $b4)) (i64.add (i64.mul (get_local $a6) (get_local $b3)) (i64.add (i64.mul (get_local $a7) (get_local $b2)) (i64.add (i64.mul (get_local $a8) (get_local $b1)) (i64.mul (get_local $a9) (get_local $b0)))))))))))))
|
|
(set_local $s10 (i64.add (get_local $c10) (i64.add (i64.mul (get_local $a0) (get_local $b10)) (i64.add (i64.mul (get_local $a1) (get_local $b9 )) (i64.add (i64.mul (get_local $a2) (get_local $b8)) (i64.add (i64.mul (get_local $a3) (get_local $b7)) (i64.add (i64.mul (get_local $a4) (get_local $b6)) (i64.add (i64.mul (get_local $a5) (get_local $b5)) (i64.add (i64.mul (get_local $a6) (get_local $b4)) (i64.add (i64.mul (get_local $a7) (get_local $b3)) (i64.add (i64.mul (get_local $a8) (get_local $b2)) (i64.add (i64.mul (get_local $a9) (get_local $b1)) (i64.mul (get_local $a10) (get_local $b0))))))))))))))
|
|
(set_local $s11 (i64.add (get_local $c11) (i64.add (i64.mul (get_local $a0) (get_local $b11)) (i64.add (i64.mul (get_local $a1) (get_local $b10)) (i64.add (i64.mul (get_local $a2) (get_local $b9)) (i64.add (i64.mul (get_local $a3) (get_local $b8)) (i64.add (i64.mul (get_local $a4) (get_local $b7)) (i64.add (i64.mul (get_local $a5) (get_local $b6)) (i64.add (i64.mul (get_local $a6) (get_local $b5)) (i64.add (i64.mul (get_local $a7) (get_local $b4)) (i64.add (i64.mul (get_local $a8) (get_local $b3)) (i64.add (i64.mul (get_local $a9) (get_local $b2)) (i64.add (i64.mul (get_local $a10) (get_local $b1)) (i64.mul (get_local $a11) (get_local $b0)))))))))))))))
|
|
(set_local $s12 (i64.add (i64.mul (get_local $a1) (get_local $b11)) (i64.add (i64.mul (get_local $a2) (get_local $b10)) (i64.add (i64.mul (get_local $a3) (get_local $b9)) (i64.add (i64.mul (get_local $a4) (get_local $b8)) (i64.add (i64.mul (get_local $a5) (get_local $b7)) (i64.add (i64.mul (get_local $a6) (get_local $b6)) (i64.add (i64.mul (get_local $a7) (get_local $b5)) (i64.add (i64.mul (get_local $a8) (get_local $b4)) (i64.add (i64.mul (get_local $a9) (get_local $b3)) (i64.add (i64.mul (get_local $a10) (get_local $b2)) (i64.mul (get_local $a11) (get_local $b1)))))))))))))
|
|
(set_local $s13 (i64.add (i64.mul (get_local $a2) (get_local $b11)) (i64.add (i64.mul (get_local $a3) (get_local $b10)) (i64.add (i64.mul (get_local $a4) (get_local $b9)) (i64.add (i64.mul (get_local $a5) (get_local $b8)) (i64.add (i64.mul (get_local $a6) (get_local $b7)) (i64.add (i64.mul (get_local $a7) (get_local $b6)) (i64.add (i64.mul (get_local $a8) (get_local $b5)) (i64.add (i64.mul (get_local $a9) (get_local $b4)) (i64.add (i64.mul (get_local $a10) (get_local $b3)) (i64.mul (get_local $a11) (get_local $b2))))))))))))
|
|
(set_local $s14 (i64.add (i64.mul (get_local $a3) (get_local $b11)) (i64.add (i64.mul (get_local $a4) (get_local $b10)) (i64.add (i64.mul (get_local $a5) (get_local $b9)) (i64.add (i64.mul (get_local $a6) (get_local $b8)) (i64.add (i64.mul (get_local $a7) (get_local $b7)) (i64.add (i64.mul (get_local $a8) (get_local $b6)) (i64.add (i64.mul (get_local $a9) (get_local $b5)) (i64.add (i64.mul (get_local $a10) (get_local $b4)) (i64.mul (get_local $a11) (get_local $b3)))))))))))
|
|
(set_local $s15 (i64.add (i64.mul (get_local $a4) (get_local $b11)) (i64.add (i64.mul (get_local $a5) (get_local $b10)) (i64.add (i64.mul (get_local $a6) (get_local $b9)) (i64.add (i64.mul (get_local $a7) (get_local $b8)) (i64.add (i64.mul (get_local $a8) (get_local $b7)) (i64.add (i64.mul (get_local $a9) (get_local $b6)) (i64.add (i64.mul (get_local $a10) (get_local $b5)) (i64.mul (get_local $a11) (get_local $b4))))))))))
|
|
(set_local $s16 (i64.add (i64.mul (get_local $a5) (get_local $b11)) (i64.add (i64.mul (get_local $a6) (get_local $b10)) (i64.add (i64.mul (get_local $a7) (get_local $b9)) (i64.add (i64.mul (get_local $a8) (get_local $b8)) (i64.add (i64.mul (get_local $a9) (get_local $b7)) (i64.add (i64.mul (get_local $a10) (get_local $b6)) (i64.mul (get_local $a11) (get_local $b5)))))))))
|
|
(set_local $s17 (i64.add (i64.mul (get_local $a6) (get_local $b11)) (i64.add (i64.mul (get_local $a7) (get_local $b10)) (i64.add (i64.mul (get_local $a8) (get_local $b9)) (i64.add (i64.mul (get_local $a9) (get_local $b8)) (i64.add (i64.mul (get_local $a10) (get_local $b7)) (i64.mul (get_local $a11) (get_local $b6))))))))
|
|
(set_local $s18 (i64.add (i64.mul (get_local $a7) (get_local $b11)) (i64.add (i64.mul (get_local $a8) (get_local $b10)) (i64.add (i64.mul (get_local $a9) (get_local $b9)) (i64.add (i64.mul (get_local $a10) (get_local $b8)) (i64.mul (get_local $a11) (get_local $b7)))))))
|
|
(set_local $s19 (i64.add (i64.mul (get_local $a8) (get_local $b11)) (i64.add (i64.mul (get_local $a9) (get_local $b10)) (i64.add (i64.mul (get_local $a10) (get_local $b9)) (i64.mul (get_local $a11) (get_local $b8))))))
|
|
(set_local $s20 (i64.add (i64.mul (get_local $a9) (get_local $b11)) (i64.add (i64.mul (get_local $a10) (get_local $b10)) (i64.mul (get_local $a11) (get_local $b9)))))
|
|
(set_local $s21 (i64.add (i64.mul (get_local $a10) (get_local $b11)) (i64.mul (get_local $a11) (get_local $b10))))
|
|
(set_local $s22 (i64.mul (get_local $a11) (get_local $b11)))
|
|
(set_local $s23 (i64.const 0))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $s0) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (i64.add (get_local $s2) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $s4) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $s6) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $s8) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (i64.add (get_local $s10) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry12 (i64.shr_s (i64.add (get_local $s12) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s13 (i64.add (get_local $s13) (get_local $carry12)))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $carry12) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry14 (i64.shr_s (i64.add (get_local $s14) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s15 (i64.add (get_local $s15) (get_local $carry14)))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $carry14) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry16 (i64.shr_s (i64.add (get_local $s16) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s17 (i64.add (get_local $s17) (get_local $carry16)))
|
|
(set_local $s16 (i64.sub (get_local $s16) (i64.mul (get_local $carry16) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry18 (i64.shr_s (i64.add (get_local $s18) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s19 (i64.add (get_local $s19) (get_local $carry18)))
|
|
(set_local $s18 (i64.sub (get_local $s18) (i64.mul (get_local $carry18) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry20 (i64.shr_s (i64.add (get_local $s20) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s21 (i64.add (get_local $s21) (get_local $carry20)))
|
|
(set_local $s20 (i64.sub (get_local $s20) (i64.mul (get_local $carry20) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry22 (i64.shr_s (i64.add (get_local $s22) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s23 (i64.add (get_local $s23) (get_local $carry22)))
|
|
(set_local $s22 (i64.sub (get_local $s22) (i64.mul (get_local $carry22) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (i64.add (get_local $s1) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (i64.add (get_local $s3) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (i64.add (get_local $s5) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $s7) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $s9) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (i64.add (get_local $s11) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry13 (i64.shr_s (i64.add (get_local $s13) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s14 (i64.add (get_local $s14) (get_local $carry13)))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $carry13) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry15 (i64.shr_s (i64.add (get_local $s15) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s16 (i64.add (get_local $s16) (get_local $carry15)))
|
|
(set_local $s15 (i64.sub (get_local $s15) (i64.mul (get_local $carry15) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry17 (i64.shr_s (i64.add (get_local $s17) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s18 (i64.add (get_local $s18) (get_local $carry17)))
|
|
(set_local $s17 (i64.sub (get_local $s17) (i64.mul (get_local $carry17) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry19 (i64.shr_s (i64.add (get_local $s19) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s20 (i64.add (get_local $s20) (get_local $carry19)))
|
|
(set_local $s19 (i64.sub (get_local $s19) (i64.mul (get_local $carry19) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry21 (i64.shr_s (i64.add (get_local $s21) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s22 (i64.add (get_local $s22) (get_local $carry21)))
|
|
(set_local $s21 (i64.sub (get_local $s21) (i64.mul (get_local $carry21) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s23) (i64.const 666643))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s23) (i64.const 470296))))
|
|
(set_local $s13 (i64.add (get_local $s13) (i64.mul (get_local $s23) (i64.const 654183))))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $s23) (i64.const 997805))))
|
|
(set_local $s15 (i64.add (get_local $s15) (i64.mul (get_local $s23) (i64.const 136657))))
|
|
(set_local $s16 (i64.sub (get_local $s16) (i64.mul (get_local $s23) (i64.const 683901))))
|
|
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s22) (i64.const 666643))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s22) (i64.const 470296))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s22) (i64.const 654183))))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $s22) (i64.const 997805))))
|
|
(set_local $s14 (i64.add (get_local $s14) (i64.mul (get_local $s22) (i64.const 136657))))
|
|
(set_local $s15 (i64.sub (get_local $s15) (i64.mul (get_local $s22) (i64.const 683901))))
|
|
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s21) (i64.const 666643))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s21) (i64.const 470296))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s21) (i64.const 654183))))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $s21) (i64.const 997805))))
|
|
(set_local $s13 (i64.add (get_local $s13) (i64.mul (get_local $s21) (i64.const 136657))))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $s21) (i64.const 683901))))
|
|
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s20) (i64.const 666643))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s20) (i64.const 470296))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s20) (i64.const 654183))))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $s20) (i64.const 997805))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s20) (i64.const 136657))))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $s20) (i64.const 683901))))
|
|
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s19) (i64.const 666643))))
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s19) (i64.const 470296))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s19) (i64.const 654183))))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $s19) (i64.const 997805))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s19) (i64.const 136657))))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $s19) (i64.const 683901))))
|
|
|
|
(set_local $s6 (i64.add (get_local $s6 ) (i64.mul (get_local $s18) (i64.const 666643))))
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s18) (i64.const 470296))))
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s18) (i64.const 654183))))
|
|
(set_local $s9 (i64.sub (get_local $s9 ) (i64.mul (get_local $s18) (i64.const 997805))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s18) (i64.const 136657))))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $s18) (i64.const 683901))))
|
|
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $s6) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $s8) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (i64.add (get_local $s10) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry12 (i64.shr_s (i64.add (get_local $s12) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s13 (i64.add (get_local $s13) (get_local $carry12)))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $carry12) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry14 (i64.shr_s (i64.add (get_local $s14) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s15 (i64.add (get_local $s15) (get_local $carry14)))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $carry14) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry16 (i64.shr_s (i64.add (get_local $s16) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s17 (i64.add (get_local $s17) (get_local $carry16)))
|
|
(set_local $s16 (i64.sub (get_local $s16) (i64.mul (get_local $carry16) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $s7) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $s9) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (i64.add (get_local $s11) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry13 (i64.shr_s (i64.add (get_local $s13) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s14 (i64.add (get_local $s14) (get_local $carry13)))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $carry13) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry15 (i64.shr_s (i64.add (get_local $s15) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s16 (i64.add (get_local $s16) (get_local $carry15)))
|
|
(set_local $s15 (i64.sub (get_local $s15) (i64.mul (get_local $carry15) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s5 (i64.add (get_local $s5 ) (i64.mul (get_local $s17) (i64.const 666643))))
|
|
(set_local $s6 (i64.add (get_local $s6 ) (i64.mul (get_local $s17) (i64.const 470296))))
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s17) (i64.const 654183))))
|
|
(set_local $s8 (i64.sub (get_local $s8 ) (i64.mul (get_local $s17) (i64.const 997805))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s17) (i64.const 136657))))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $s17) (i64.const 683901))))
|
|
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s16) (i64.const 666643))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s16) (i64.const 470296))))
|
|
(set_local $s6 (i64.add (get_local $s6) (i64.mul (get_local $s16) (i64.const 654183))))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $s16) (i64.const 997805))))
|
|
(set_local $s8 (i64.add (get_local $s8) (i64.mul (get_local $s16) (i64.const 136657))))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $s16) (i64.const 683901))))
|
|
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s15) (i64.const 666643))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s15) (i64.const 470296))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s15) (i64.const 654183))))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $s15) (i64.const 997805))))
|
|
(set_local $s7 (i64.add (get_local $s7) (i64.mul (get_local $s15) (i64.const 136657))))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $s15) (i64.const 683901))))
|
|
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s14) (i64.const 666643))))
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s14) (i64.const 470296))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s14) (i64.const 654183))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s14) (i64.const 997805))))
|
|
(set_local $s6 (i64.add (get_local $s6) (i64.mul (get_local $s14) (i64.const 136657))))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $s14) (i64.const 683901))))
|
|
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s13) (i64.const 666643))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s13) (i64.const 470296))))
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s13) (i64.const 654183))))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $s13) (i64.const 997805))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s13) (i64.const 136657))))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $s13) (i64.const 683901))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
(set_local $s12 (i64.const 0))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $s0) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (i64.add (get_local $s2) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $s4) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $s6) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $s8) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (i64.add (get_local $s10) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (i64.add (get_local $s1) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (i64.add (get_local $s3) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (i64.add (get_local $s5) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $s7) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $s9) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (i64.add (get_local $s11) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
(set_local $s12 (i64.const 0))
|
|
|
|
(set_local $carry0 (i64.shr_s (get_local $s0) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (get_local $s1) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (get_local $s2) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (get_local $s3) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (get_local $s4) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (get_local $s5) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (get_local $s6) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (get_local $s7) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (get_local $s8) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (get_local $s9) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (get_local $s10) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (get_local $s11) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
|
|
(set_local $carry0 (i64.shr_s (get_local $s0) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (get_local $s1) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (get_local $s2) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (get_local $s3) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (get_local $s4) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (get_local $s5) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (get_local $s6) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (get_local $s7) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (get_local $s8) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (get_local $s9) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (get_local $s10) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (get_local $s0) (i64.const 0xff))
|
|
(i64.and (get_local $s0) (i64.const 0xff00))
|
|
(i64.or)
|
|
(get_local $s0)
|
|
(i64.shl (i64.mul (get_local $s1) (i64.const 32)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.shl (i64.mul (get_local $s2) (i64.const 4)) (i64.const 40))
|
|
(i64.or)
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s2) (i64.const 42))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s2) (i64.const 42))
|
|
(i64.shl (i64.mul (get_local $s3) (i64.const 128)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=0)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s3) (i64.const 1)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s3) (i64.const 1)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s3) (i64.const 1))
|
|
(i64.shl (i64.mul (get_local $s4) (i64.const 16)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.shl (i64.mul (get_local $s5) (i64.const 2)) (i64.const 40))
|
|
(i64.or)
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s5) (i64.const 41))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s5) (i64.const 41))
|
|
(i64.shl (i64.mul (get_local $s6) (i64.const 64)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=8)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s6) (i64.const 2)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s6) (i64.const 2)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s6) (i64.const 2))
|
|
(i64.shl (i64.mul (get_local $s7) (i64.const 8)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s7) (i64.const 19))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s7) (i64.const 19))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.shl (i64.mul (get_local $s9) (i64.const 32)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=16)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s9) (i64.const 3)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s9) (i64.const 3)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s9) (i64.const 3))
|
|
(i64.shl (i64.mul (get_local $s10) (i64.const 4)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s10) (i64.const 18))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s10) (i64.const 18))
|
|
(i64.shl (i64.mul (get_local $s11) (i64.const 128)) (i64.const 32))
|
|
(i64.or)
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=24))
|
|
|
|
(func $sc25519_reduce (export "sc25519_reduce") (param $s i32)
|
|
(local $s0 i64)
|
|
(local $s1 i64)
|
|
(local $s2 i64)
|
|
(local $s3 i64)
|
|
(local $s4 i64)
|
|
(local $s5 i64)
|
|
(local $s6 i64)
|
|
(local $s7 i64)
|
|
(local $s8 i64)
|
|
(local $s9 i64)
|
|
(local $s10 i64)
|
|
(local $s11 i64)
|
|
(local $s12 i64)
|
|
(local $s13 i64)
|
|
(local $s14 i64)
|
|
(local $s15 i64)
|
|
(local $s16 i64)
|
|
(local $s17 i64)
|
|
(local $s18 i64)
|
|
(local $s19 i64)
|
|
(local $s20 i64)
|
|
(local $s21 i64)
|
|
(local $s22 i64)
|
|
(local $s23 i64)
|
|
|
|
(local $carry0 i64)
|
|
(local $carry1 i64)
|
|
(local $carry2 i64)
|
|
(local $carry3 i64)
|
|
(local $carry4 i64)
|
|
(local $carry5 i64)
|
|
(local $carry6 i64)
|
|
(local $carry7 i64)
|
|
(local $carry8 i64)
|
|
(local $carry9 i64)
|
|
(local $carry10 i64)
|
|
(local $carry11 i64)
|
|
(local $carry12 i64)
|
|
(local $carry13 i64)
|
|
(local $carry14 i64)
|
|
(local $carry15 i64)
|
|
(local $carry16 i64)
|
|
|
|
(set_local $s0 (i64.load32_u offset=0 (get_local $s)))
|
|
(set_local $s1 (i64.load32_u offset=4 (get_local $s)))
|
|
(set_local $s2 (i64.load32_u offset=8 (get_local $s)))
|
|
(set_local $s3 (i64.load32_u offset=12 (get_local $s)))
|
|
(set_local $s4 (i64.load32_u offset=16 (get_local $s)))
|
|
(set_local $s5 (i64.load32_u offset=20 (get_local $s)))
|
|
(set_local $s6 (i64.load32_u offset=24 (get_local $s)))
|
|
(set_local $s7 (i64.load32_u offset=28 (get_local $s)))
|
|
(set_local $s8 (i64.load32_u offset=32 (get_local $s)))
|
|
(set_local $s9 (i64.load32_u offset=36 (get_local $s)))
|
|
(set_local $s10 (i64.load32_u offset=40 (get_local $s)))
|
|
(set_local $s11 (i64.load32_u offset=44 (get_local $s)))
|
|
(set_local $s12 (i64.load32_u offset=48 (get_local $s)))
|
|
(set_local $s13 (i64.load32_u offset=52 (get_local $s)))
|
|
(set_local $s14 (i64.load32_u offset=56 (get_local $s)))
|
|
(set_local $s15 (i64.load32_u offset=60 (get_local $s)))
|
|
(set_local $s16 (i64.load32_u offset=64 (get_local $s)))
|
|
(set_local $s17 (i64.load32_u offset=68 (get_local $s)))
|
|
(set_local $s18 (i64.load32_u offset=72 (get_local $s)))
|
|
(set_local $s19 (i64.load32_u offset=76 (get_local $s)))
|
|
(set_local $s20 (i64.load32_u offset=80 (get_local $s)))
|
|
(set_local $s21 (i64.load32_u offset=84 (get_local $s)))
|
|
(set_local $s22 (i64.load32_u offset=88 (get_local $s)))
|
|
(set_local $s23 (i64.load32_u offset=92 (get_local $s)))
|
|
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s23) (i64.const 666643))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s23) (i64.const 470296))))
|
|
(set_local $s13 (i64.add (get_local $s13) (i64.mul (get_local $s23) (i64.const 654183))))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $s23) (i64.const 997805))))
|
|
(set_local $s15 (i64.add (get_local $s15) (i64.mul (get_local $s23) (i64.const 136657))))
|
|
(set_local $s16 (i64.sub (get_local $s16) (i64.mul (get_local $s23) (i64.const 683901))))
|
|
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s22) (i64.const 666643))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s22) (i64.const 470296))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s22) (i64.const 654183))))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $s22) (i64.const 997805))))
|
|
(set_local $s14 (i64.add (get_local $s14) (i64.mul (get_local $s22) (i64.const 136657))))
|
|
(set_local $s15 (i64.sub (get_local $s15) (i64.mul (get_local $s22) (i64.const 683901))))
|
|
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s21) (i64.const 666643))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s21) (i64.const 470296))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s21) (i64.const 654183))))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $s21) (i64.const 997805))))
|
|
(set_local $s13 (i64.add (get_local $s13) (i64.mul (get_local $s21) (i64.const 136657))))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $s21) (i64.const 683901))))
|
|
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s20) (i64.const 666643))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s20) (i64.const 470296))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s20) (i64.const 654183))))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $s20) (i64.const 997805))))
|
|
(set_local $s12 (i64.add (get_local $s12) (i64.mul (get_local $s20) (i64.const 136657))))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $s20) (i64.const 683901))))
|
|
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s19) (i64.const 666643))))
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s19) (i64.const 470296))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s19) (i64.const 654183))))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $s19) (i64.const 997805))))
|
|
(set_local $s11 (i64.add (get_local $s11) (i64.mul (get_local $s19) (i64.const 136657))))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $s19) (i64.const 683901))))
|
|
|
|
(set_local $s6 (i64.add (get_local $s6 ) (i64.mul (get_local $s18) (i64.const 666643))))
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s18) (i64.const 470296))))
|
|
(set_local $s8 (i64.add (get_local $s8 ) (i64.mul (get_local $s18) (i64.const 654183))))
|
|
(set_local $s9 (i64.sub (get_local $s9 ) (i64.mul (get_local $s18) (i64.const 997805))))
|
|
(set_local $s10 (i64.add (get_local $s10) (i64.mul (get_local $s18) (i64.const 136657))))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $s18) (i64.const 683901))))
|
|
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $s6) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $s8) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (i64.add (get_local $s10) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry12 (i64.shr_s (i64.add (get_local $s12) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s13 (i64.add (get_local $s13) (get_local $carry12)))
|
|
(set_local $s12 (i64.sub (get_local $s12) (i64.mul (get_local $carry12) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry14 (i64.shr_s (i64.add (get_local $s14) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s15 (i64.add (get_local $s15) (get_local $carry14)))
|
|
(set_local $s14 (i64.sub (get_local $s14) (i64.mul (get_local $carry14) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry16 (i64.shr_s (i64.add (get_local $s16) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s17 (i64.add (get_local $s17) (get_local $carry16)))
|
|
(set_local $s16 (i64.sub (get_local $s16) (i64.mul (get_local $carry16) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $s7) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $s9) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (i64.add (get_local $s11) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry13 (i64.shr_s (i64.add (get_local $s13) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s14 (i64.add (get_local $s14) (get_local $carry13)))
|
|
(set_local $s13 (i64.sub (get_local $s13) (i64.mul (get_local $carry13) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry15 (i64.shr_s (i64.add (get_local $s15) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s16 (i64.add (get_local $s16) (get_local $carry15)))
|
|
(set_local $s15 (i64.sub (get_local $s15) (i64.mul (get_local $carry15) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s5 (i64.add (get_local $s5 ) (i64.mul (get_local $s17) (i64.const 666643))))
|
|
(set_local $s6 (i64.add (get_local $s6 ) (i64.mul (get_local $s17) (i64.const 470296))))
|
|
(set_local $s7 (i64.add (get_local $s7 ) (i64.mul (get_local $s17) (i64.const 654183))))
|
|
(set_local $s8 (i64.sub (get_local $s8 ) (i64.mul (get_local $s17) (i64.const 997805))))
|
|
(set_local $s9 (i64.add (get_local $s9 ) (i64.mul (get_local $s17) (i64.const 136657))))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $s17) (i64.const 683901))))
|
|
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s16) (i64.const 666643))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s16) (i64.const 470296))))
|
|
(set_local $s6 (i64.add (get_local $s6) (i64.mul (get_local $s16) (i64.const 654183))))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $s16) (i64.const 997805))))
|
|
(set_local $s8 (i64.add (get_local $s8) (i64.mul (get_local $s16) (i64.const 136657))))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $s16) (i64.const 683901))))
|
|
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s15) (i64.const 666643))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s15) (i64.const 470296))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s15) (i64.const 654183))))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $s15) (i64.const 997805))))
|
|
(set_local $s7 (i64.add (get_local $s7) (i64.mul (get_local $s15) (i64.const 136657))))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $s15) (i64.const 683901))))
|
|
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s14) (i64.const 666643))))
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s14) (i64.const 470296))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s14) (i64.const 654183))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s14) (i64.const 997805))))
|
|
(set_local $s6 (i64.add (get_local $s6) (i64.mul (get_local $s14) (i64.const 136657))))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $s14) (i64.const 683901))))
|
|
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s13) (i64.const 666643))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s13) (i64.const 470296))))
|
|
(set_local $s3 (i64.add (get_local $s3) (i64.mul (get_local $s13) (i64.const 654183))))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $s13) (i64.const 997805))))
|
|
(set_local $s5 (i64.add (get_local $s5) (i64.mul (get_local $s13) (i64.const 136657))))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $s13) (i64.const 683901))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
(set_local $s12 (i64.const 0))
|
|
|
|
(set_local $carry0 (i64.shr_s (i64.add (get_local $s0) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (i64.add (get_local $s2) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (i64.add (get_local $s4) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (i64.add (get_local $s6) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (i64.add (get_local $s8) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (i64.add (get_local $s10) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (i64.add (get_local $s1) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (i64.add (get_local $s3) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (i64.add (get_local $s5) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (i64.add (get_local $s7) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (i64.add (get_local $s9) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (i64.add (get_local $s11) (i64.shl (i64.const 1) (i64.const 20))) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
(set_local $s12 (i64.const 0))
|
|
|
|
(set_local $carry0 (i64.shr_s (get_local $s0) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (get_local $s1) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (get_local $s2) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (get_local $s3) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (get_local $s4) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (get_local $s5) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (get_local $s6) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (get_local $s7) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (get_local $s8) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (get_local $s9) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (get_local $s10) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry11 (i64.shr_s (get_local $s11) (i64.const 21)))
|
|
(set_local $s12 (i64.add (get_local $s12) (get_local $carry11)))
|
|
(set_local $s11 (i64.sub (get_local $s11) (i64.mul (get_local $carry11) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $s0 (i64.add (get_local $s0) (i64.mul (get_local $s12) (i64.const 666643))))
|
|
(set_local $s1 (i64.add (get_local $s1) (i64.mul (get_local $s12) (i64.const 470296))))
|
|
(set_local $s2 (i64.add (get_local $s2) (i64.mul (get_local $s12) (i64.const 654183))))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $s12) (i64.const 997805))))
|
|
(set_local $s4 (i64.add (get_local $s4) (i64.mul (get_local $s12) (i64.const 136657))))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $s12) (i64.const 683901))))
|
|
|
|
(set_local $carry0 (i64.shr_s (get_local $s0) (i64.const 21)))
|
|
(set_local $s1 (i64.add (get_local $s1) (get_local $carry0)))
|
|
(set_local $s0 (i64.sub (get_local $s0) (i64.mul (get_local $carry0) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry1 (i64.shr_s (get_local $s1) (i64.const 21)))
|
|
(set_local $s2 (i64.add (get_local $s2) (get_local $carry1)))
|
|
(set_local $s1 (i64.sub (get_local $s1) (i64.mul (get_local $carry1) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry2 (i64.shr_s (get_local $s2) (i64.const 21)))
|
|
(set_local $s3 (i64.add (get_local $s3) (get_local $carry2)))
|
|
(set_local $s2 (i64.sub (get_local $s2) (i64.mul (get_local $carry2) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry3 (i64.shr_s (get_local $s3) (i64.const 21)))
|
|
(set_local $s4 (i64.add (get_local $s4) (get_local $carry3)))
|
|
(set_local $s3 (i64.sub (get_local $s3) (i64.mul (get_local $carry3) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry4 (i64.shr_s (get_local $s4) (i64.const 21)))
|
|
(set_local $s5 (i64.add (get_local $s5) (get_local $carry4)))
|
|
(set_local $s4 (i64.sub (get_local $s4) (i64.mul (get_local $carry4) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry5 (i64.shr_s (get_local $s5) (i64.const 21)))
|
|
(set_local $s6 (i64.add (get_local $s6) (get_local $carry5)))
|
|
(set_local $s5 (i64.sub (get_local $s5) (i64.mul (get_local $carry5) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry6 (i64.shr_s (get_local $s6) (i64.const 21)))
|
|
(set_local $s7 (i64.add (get_local $s7) (get_local $carry6)))
|
|
(set_local $s6 (i64.sub (get_local $s6) (i64.mul (get_local $carry6) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry7 (i64.shr_s (get_local $s7) (i64.const 21)))
|
|
(set_local $s8 (i64.add (get_local $s8) (get_local $carry7)))
|
|
(set_local $s7 (i64.sub (get_local $s7) (i64.mul (get_local $carry7) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry8 (i64.shr_s (get_local $s8) (i64.const 21)))
|
|
(set_local $s9 (i64.add (get_local $s9) (get_local $carry8)))
|
|
(set_local $s8 (i64.sub (get_local $s8) (i64.mul (get_local $carry8) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry9 (i64.shr_s (get_local $s9) (i64.const 21)))
|
|
(set_local $s10 (i64.add (get_local $s10) (get_local $carry9)))
|
|
(set_local $s9 (i64.sub (get_local $s9) (i64.mul (get_local $carry9) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(set_local $carry10 (i64.shr_s (get_local $s10) (i64.const 21)))
|
|
(set_local $s11 (i64.add (get_local $s11) (get_local $carry10)))
|
|
(set_local $s10 (i64.sub (get_local $s10) (i64.mul (get_local $carry10) (i64.shl (i64.const 1) (i64.const 21)))))
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (get_local $s0) (i64.const 0xff))
|
|
(i64.and (get_local $s0) (i64.const 0xff00))
|
|
(i64.or)
|
|
(get_local $s0)
|
|
(i64.shl (i64.mul (get_local $s1) (i64.const 32)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s1) (i64.const 21))
|
|
(i64.shl (i64.mul (get_local $s2) (i64.const 4)) (i64.const 40))
|
|
(i64.or)
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s2) (i64.const 42))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s2) (i64.const 42))
|
|
(i64.shl (i64.mul (get_local $s3) (i64.const 128)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=0)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s3) (i64.const 1)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s3) (i64.const 1)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s3) (i64.const 1))
|
|
(i64.shl (i64.mul (get_local $s4) (i64.const 16)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s4) (i64.const 20))
|
|
(i64.shl (i64.mul (get_local $s5) (i64.const 2)) (i64.const 40))
|
|
(i64.or)
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s5) (i64.const 41))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s5) (i64.const 41))
|
|
(i64.shl (i64.mul (get_local $s6) (i64.const 64)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=8)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s6) (i64.const 2)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s6) (i64.const 2)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s6) (i64.const 2))
|
|
(i64.shl (i64.mul (get_local $s7) (i64.const 8)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s7) (i64.const 19))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s7) (i64.const 19))
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s8) (i64.const 40))
|
|
(i64.shl (i64.mul (get_local $s9) (i64.const 32)) (i64.const 56))
|
|
(i64.or)
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=16)
|
|
|
|
(get_local $s)
|
|
|
|
(i64.and (i64.shr_s (get_local $s9) (i64.const 3)) (i64.const 0xff))
|
|
(i64.and (i64.shr_s (get_local $s9) (i64.const 3)) (i64.const 0xff00))
|
|
(i64.or)
|
|
(i64.shr_s (get_local $s9) (i64.const 3))
|
|
(i64.shl (i64.mul (get_local $s10) (i64.const 4)) (i64.const 16))
|
|
(i64.or)
|
|
(i64.const 0xff0000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s10) (i64.const 18))
|
|
(i64.const 0xff000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s10) (i64.const 18))
|
|
(i64.shl (i64.mul (get_local $s11) (i64.const 128)) (i64.const 32))
|
|
(i64.or)
|
|
(i64.const 0xff00000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff0000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
(i64.shl (get_local $s11) (i64.const 39))
|
|
(i64.const 0xff00000000000000)
|
|
(i64.and)
|
|
(i64.or)
|
|
|
|
(i64.store offset=24))
|
|
)
|