forked from kozorizki/binaryen
Br and BrOn can consider the code before and after them connected if it might be reached (which is the case if the Br has a condition, which BrOn always has). The wasm2js changes may look a little odd as some of them have this: i64toi32_i32$1 = i64toi32_i32$2; i64toi32_i32$1 = i64toi32_i32$2; I looked into that and the reason is that those outputs are not optimized, and also even in unoptimized wasm2js we do run simplify-locals once (to try to reduce the downsides of flatten). As a result, this PR makes a difference there, and that difference can lead to such odd duplicated code after other operations. However, there are no changes to optimized wasm2js outputs, so there is no actual problem. Followup to #5860.
1721 lines
61 KiB
JavaScript
1721 lines
61 KiB
JavaScript
|
|
function asmFunc(imports) {
|
|
var Math_imul = Math.imul;
|
|
var Math_fround = Math.fround;
|
|
var Math_abs = Math.abs;
|
|
var Math_clz32 = Math.clz32;
|
|
var Math_min = Math.min;
|
|
var Math_max = Math.max;
|
|
var Math_floor = Math.floor;
|
|
var Math_ceil = Math.ceil;
|
|
var Math_trunc = Math.trunc;
|
|
var Math_sqrt = Math.sqrt;
|
|
var __wasm_intrinsics_temp_i64 = 0;
|
|
var __wasm_intrinsics_temp_i64$hi = 0;
|
|
var i64toi32_i32$HIGH_BITS = 0;
|
|
function $0(x, y) {
|
|
x = x | 0;
|
|
y = y | 0;
|
|
(x | 0) / (y | 0) | 0;
|
|
}
|
|
|
|
function $1(x, y) {
|
|
x = x | 0;
|
|
y = y | 0;
|
|
(x >>> 0) / (y >>> 0) | 0;
|
|
}
|
|
|
|
function $2(x, x$hi, y, y$hi) {
|
|
x = x | 0;
|
|
x$hi = x$hi | 0;
|
|
y = y | 0;
|
|
y$hi = y$hi | 0;
|
|
__wasm_i64_sdiv(x | 0, x$hi | 0, y | 0, y$hi | 0) | 0;
|
|
}
|
|
|
|
function $3(x, x$hi, y, y$hi) {
|
|
x = x | 0;
|
|
x$hi = x$hi | 0;
|
|
y = y | 0;
|
|
y$hi = y$hi | 0;
|
|
__wasm_i64_udiv(x | 0, x$hi | 0, y | 0, y$hi | 0) | 0;
|
|
}
|
|
|
|
function legalstub$2($0_1, $1_1, $2_1, $3_1) {
|
|
$0_1 = $0_1 | 0;
|
|
$1_1 = $1_1 | 0;
|
|
$2_1 = $2_1 | 0;
|
|
$3_1 = $3_1 | 0;
|
|
var i64toi32_i32$2 = 0, i64toi32_i32$1 = 0, i64toi32_i32$0 = 0, i64toi32_i32$4 = 0, i64toi32_i32$3 = 0, $19 = 0, $20 = 0, $5 = 0, $5$hi = 0, $8$hi = 0, $9 = 0, $9$hi = 0, $11 = 0, $11$hi = 0, $14$hi = 0, $15 = 0, $15$hi = 0;
|
|
i64toi32_i32$0 = 0;
|
|
$5 = $0_1;
|
|
$5$hi = i64toi32_i32$0;
|
|
i64toi32_i32$0 = 0;
|
|
i64toi32_i32$2 = $1_1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
$19 = 0;
|
|
} else {
|
|
i64toi32_i32$1 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$0 << i64toi32_i32$4 | 0) | 0;
|
|
$19 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
}
|
|
$8$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = $5$hi;
|
|
i64toi32_i32$0 = $5;
|
|
i64toi32_i32$2 = $8$hi;
|
|
i64toi32_i32$3 = $19;
|
|
i64toi32_i32$2 = i64toi32_i32$1 | i64toi32_i32$2 | 0;
|
|
$9 = i64toi32_i32$0 | i64toi32_i32$3 | 0;
|
|
$9$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = 0;
|
|
$11 = $2_1;
|
|
$11$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$1 = $3_1;
|
|
i64toi32_i32$0 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$0 = i64toi32_i32$1 << i64toi32_i32$4 | 0;
|
|
$20 = 0;
|
|
} else {
|
|
i64toi32_i32$0 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$1 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$2 << i64toi32_i32$4 | 0) | 0;
|
|
$20 = i64toi32_i32$1 << i64toi32_i32$4 | 0;
|
|
}
|
|
$14$hi = i64toi32_i32$0;
|
|
i64toi32_i32$0 = $11$hi;
|
|
i64toi32_i32$2 = $11;
|
|
i64toi32_i32$1 = $14$hi;
|
|
i64toi32_i32$3 = $20;
|
|
i64toi32_i32$1 = i64toi32_i32$0 | i64toi32_i32$1 | 0;
|
|
$15 = i64toi32_i32$2 | i64toi32_i32$3 | 0;
|
|
$15$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = $9$hi;
|
|
i64toi32_i32$2 = $15$hi;
|
|
$2($9 | 0, i64toi32_i32$1 | 0, $15 | 0, i64toi32_i32$2 | 0);
|
|
}
|
|
|
|
function legalstub$3($0_1, $1_1, $2_1, $3_1) {
|
|
$0_1 = $0_1 | 0;
|
|
$1_1 = $1_1 | 0;
|
|
$2_1 = $2_1 | 0;
|
|
$3_1 = $3_1 | 0;
|
|
var i64toi32_i32$2 = 0, i64toi32_i32$1 = 0, i64toi32_i32$0 = 0, i64toi32_i32$4 = 0, i64toi32_i32$3 = 0, $19 = 0, $20 = 0, $5 = 0, $5$hi = 0, $8$hi = 0, $9 = 0, $9$hi = 0, $11 = 0, $11$hi = 0, $14$hi = 0, $15 = 0, $15$hi = 0;
|
|
i64toi32_i32$0 = 0;
|
|
$5 = $0_1;
|
|
$5$hi = i64toi32_i32$0;
|
|
i64toi32_i32$0 = 0;
|
|
i64toi32_i32$2 = $1_1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
$19 = 0;
|
|
} else {
|
|
i64toi32_i32$1 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$0 << i64toi32_i32$4 | 0) | 0;
|
|
$19 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
}
|
|
$8$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = $5$hi;
|
|
i64toi32_i32$0 = $5;
|
|
i64toi32_i32$2 = $8$hi;
|
|
i64toi32_i32$3 = $19;
|
|
i64toi32_i32$2 = i64toi32_i32$1 | i64toi32_i32$2 | 0;
|
|
$9 = i64toi32_i32$0 | i64toi32_i32$3 | 0;
|
|
$9$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = 0;
|
|
$11 = $2_1;
|
|
$11$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$1 = $3_1;
|
|
i64toi32_i32$0 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$0 = i64toi32_i32$1 << i64toi32_i32$4 | 0;
|
|
$20 = 0;
|
|
} else {
|
|
i64toi32_i32$0 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$1 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$2 << i64toi32_i32$4 | 0) | 0;
|
|
$20 = i64toi32_i32$1 << i64toi32_i32$4 | 0;
|
|
}
|
|
$14$hi = i64toi32_i32$0;
|
|
i64toi32_i32$0 = $11$hi;
|
|
i64toi32_i32$2 = $11;
|
|
i64toi32_i32$1 = $14$hi;
|
|
i64toi32_i32$3 = $20;
|
|
i64toi32_i32$1 = i64toi32_i32$0 | i64toi32_i32$1 | 0;
|
|
$15 = i64toi32_i32$2 | i64toi32_i32$3 | 0;
|
|
$15$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = $9$hi;
|
|
i64toi32_i32$2 = $15$hi;
|
|
$3($9 | 0, i64toi32_i32$1 | 0, $15 | 0, i64toi32_i32$2 | 0);
|
|
}
|
|
|
|
function _ZN17compiler_builtins3int4sdiv3Div3div17he78fc483e41d7ec7E(var$0, var$0$hi, var$1, var$1$hi) {
|
|
var$0 = var$0 | 0;
|
|
var$0$hi = var$0$hi | 0;
|
|
var$1 = var$1 | 0;
|
|
var$1$hi = var$1$hi | 0;
|
|
var i64toi32_i32$1 = 0, i64toi32_i32$2 = 0, i64toi32_i32$4 = 0, i64toi32_i32$3 = 0, i64toi32_i32$0 = 0, i64toi32_i32$5 = 0, var$2 = 0, var$2$hi = 0, i64toi32_i32$6 = 0, $21 = 0, $22 = 0, $23 = 0, $7$hi = 0, $9 = 0, $9$hi = 0, $14$hi = 0, $16$hi = 0, $17 = 0, $17$hi = 0, $23$hi = 0;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$2 = var$0;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 63;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$0 >> 31 | 0;
|
|
$21 = i64toi32_i32$0 >> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$0 >> i64toi32_i32$4 | 0;
|
|
$21 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$0 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$2 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$2 = $21;
|
|
var$2$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$1 = var$2$hi;
|
|
i64toi32_i32$0 = var$2;
|
|
i64toi32_i32$2 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$2 = i64toi32_i32$1 ^ i64toi32_i32$2 | 0;
|
|
$7$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = i64toi32_i32$1;
|
|
i64toi32_i32$2 = $7$hi;
|
|
i64toi32_i32$1 = i64toi32_i32$0 ^ i64toi32_i32$3 | 0;
|
|
i64toi32_i32$0 = var$2$hi;
|
|
i64toi32_i32$3 = var$2;
|
|
i64toi32_i32$4 = i64toi32_i32$1 - i64toi32_i32$3 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$1 >>> 0 < i64toi32_i32$3 >>> 0;
|
|
i64toi32_i32$5 = i64toi32_i32$6 + i64toi32_i32$0 | 0;
|
|
i64toi32_i32$5 = i64toi32_i32$2 - i64toi32_i32$5 | 0;
|
|
$9 = i64toi32_i32$4;
|
|
$9$hi = i64toi32_i32$5;
|
|
i64toi32_i32$5 = var$1$hi;
|
|
i64toi32_i32$2 = var$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 63;
|
|
i64toi32_i32$0 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$5 >> 31 | 0;
|
|
$22 = i64toi32_i32$5 >> i64toi32_i32$0 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$5 >> i64toi32_i32$0 | 0;
|
|
$22 = (((1 << i64toi32_i32$0 | 0) - 1 | 0) & i64toi32_i32$5 | 0) << (32 - i64toi32_i32$0 | 0) | 0 | (i64toi32_i32$2 >>> i64toi32_i32$0 | 0) | 0;
|
|
}
|
|
var$2 = $22;
|
|
var$2$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$1$hi;
|
|
i64toi32_i32$1 = var$2$hi;
|
|
i64toi32_i32$5 = var$2;
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$3 = var$1;
|
|
i64toi32_i32$2 = i64toi32_i32$1 ^ i64toi32_i32$2 | 0;
|
|
$14$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = i64toi32_i32$1;
|
|
i64toi32_i32$2 = $14$hi;
|
|
i64toi32_i32$1 = i64toi32_i32$5 ^ i64toi32_i32$3 | 0;
|
|
i64toi32_i32$5 = var$2$hi;
|
|
i64toi32_i32$3 = var$2;
|
|
i64toi32_i32$0 = i64toi32_i32$1 - i64toi32_i32$3 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$1 >>> 0 < i64toi32_i32$3 >>> 0;
|
|
i64toi32_i32$4 = i64toi32_i32$6 + i64toi32_i32$5 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$2 - i64toi32_i32$4 | 0;
|
|
$16$hi = i64toi32_i32$4;
|
|
i64toi32_i32$4 = $9$hi;
|
|
i64toi32_i32$1 = $16$hi;
|
|
i64toi32_i32$1 = __wasm_i64_udiv($9 | 0, i64toi32_i32$4 | 0, i64toi32_i32$0 | 0, i64toi32_i32$1 | 0) | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$HIGH_BITS;
|
|
$17 = i64toi32_i32$1;
|
|
$17$hi = i64toi32_i32$4;
|
|
i64toi32_i32$4 = var$1$hi;
|
|
i64toi32_i32$4 = var$0$hi;
|
|
i64toi32_i32$4 = var$1$hi;
|
|
i64toi32_i32$2 = var$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$1 = i64toi32_i32$4 ^ i64toi32_i32$1 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$2 ^ i64toi32_i32$3 | 0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$3 = 63;
|
|
i64toi32_i32$5 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$1 >> 31 | 0;
|
|
$23 = i64toi32_i32$1 >> i64toi32_i32$5 | 0;
|
|
} else {
|
|
i64toi32_i32$2 = i64toi32_i32$1 >> i64toi32_i32$5 | 0;
|
|
$23 = (((1 << i64toi32_i32$5 | 0) - 1 | 0) & i64toi32_i32$1 | 0) << (32 - i64toi32_i32$5 | 0) | 0 | (i64toi32_i32$4 >>> i64toi32_i32$5 | 0) | 0;
|
|
}
|
|
var$0 = $23;
|
|
var$0$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = $17$hi;
|
|
i64toi32_i32$1 = $17;
|
|
i64toi32_i32$4 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$4 = i64toi32_i32$2 ^ i64toi32_i32$4 | 0;
|
|
$23$hi = i64toi32_i32$4;
|
|
i64toi32_i32$4 = var$0$hi;
|
|
i64toi32_i32$4 = $23$hi;
|
|
i64toi32_i32$2 = i64toi32_i32$1 ^ i64toi32_i32$3 | 0;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$5 = i64toi32_i32$2 - i64toi32_i32$3 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$2 >>> 0 < i64toi32_i32$3 >>> 0;
|
|
i64toi32_i32$0 = i64toi32_i32$6 + i64toi32_i32$1 | 0;
|
|
i64toi32_i32$0 = i64toi32_i32$4 - i64toi32_i32$0 | 0;
|
|
i64toi32_i32$2 = i64toi32_i32$5;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$0;
|
|
return i64toi32_i32$2 | 0;
|
|
}
|
|
|
|
function _ZN17compiler_builtins3int4udiv10divmod_u6417h6026910b5ed08e40E(var$0, var$0$hi, var$1, var$1$hi) {
|
|
var$0 = var$0 | 0;
|
|
var$0$hi = var$0$hi | 0;
|
|
var$1 = var$1 | 0;
|
|
var$1$hi = var$1$hi | 0;
|
|
var i64toi32_i32$2 = 0, i64toi32_i32$3 = 0, i64toi32_i32$4 = 0, i64toi32_i32$1 = 0, i64toi32_i32$0 = 0, i64toi32_i32$5 = 0, var$2 = 0, var$3 = 0, var$4 = 0, var$5 = 0, var$5$hi = 0, var$6 = 0, var$6$hi = 0, i64toi32_i32$6 = 0, $37 = 0, $38 = 0, $39 = 0, $40 = 0, $41 = 0, $42 = 0, $43 = 0, $44 = 0, var$8$hi = 0, $45 = 0, $46 = 0, $47 = 0, $48 = 0, var$7$hi = 0, $49 = 0, $63$hi = 0, $65 = 0, $65$hi = 0, $120$hi = 0, $129$hi = 0, $134$hi = 0, var$8 = 0, $140 = 0, $140$hi = 0, $142$hi = 0, $144 = 0, $144$hi = 0, $151 = 0, $151$hi = 0, $154$hi = 0, var$7 = 0, $165$hi = 0;
|
|
label$1 : {
|
|
label$2 : {
|
|
label$3 : {
|
|
label$4 : {
|
|
label$5 : {
|
|
label$6 : {
|
|
label$7 : {
|
|
label$8 : {
|
|
label$9 : {
|
|
label$10 : {
|
|
label$11 : {
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$2 = var$0;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = 0;
|
|
$37 = i64toi32_i32$0 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$0 >>> i64toi32_i32$4 | 0;
|
|
$37 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$0 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$2 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$2 = $37;
|
|
if (var$2) {
|
|
i64toi32_i32$1 = var$1$hi;
|
|
var$3 = var$1;
|
|
if (!var$3) {
|
|
break label$11
|
|
}
|
|
i64toi32_i32$0 = var$3;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = 0;
|
|
$38 = i64toi32_i32$1 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$2 = i64toi32_i32$1 >>> i64toi32_i32$4 | 0;
|
|
$38 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$1 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$0 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$4 = $38;
|
|
if (!var$4) {
|
|
break label$9
|
|
}
|
|
var$2 = Math_clz32(var$4) - Math_clz32(var$2) | 0;
|
|
if (var$2 >>> 0 <= 31 >>> 0) {
|
|
break label$8
|
|
}
|
|
break label$2;
|
|
}
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$1 = var$1;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$3 = 0;
|
|
if (i64toi32_i32$2 >>> 0 > i64toi32_i32$0 >>> 0 | ((i64toi32_i32$2 | 0) == (i64toi32_i32$0 | 0) & i64toi32_i32$1 >>> 0 >= i64toi32_i32$3 >>> 0 | 0) | 0) {
|
|
break label$2
|
|
}
|
|
i64toi32_i32$1 = var$0$hi;
|
|
var$2 = var$0;
|
|
i64toi32_i32$1 = i64toi32_i32$2;
|
|
i64toi32_i32$1 = i64toi32_i32$2;
|
|
var$3 = var$1;
|
|
var$2 = (var$2 >>> 0) / (var$3 >>> 0) | 0;
|
|
i64toi32_i32$1 = 0;
|
|
__wasm_intrinsics_temp_i64 = var$0 - Math_imul(var$2, var$3) | 0;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$2 = var$2;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
|
|
return i64toi32_i32$2 | 0;
|
|
}
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$3 = var$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = 0;
|
|
$39 = i64toi32_i32$2 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$2 >>> i64toi32_i32$4 | 0;
|
|
$39 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$2 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$3 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$3 = $39;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
if (!var$0) {
|
|
break label$7
|
|
}
|
|
if (!var$3) {
|
|
break label$6
|
|
}
|
|
var$4 = var$3 + -1 | 0;
|
|
if (var$4 & var$3 | 0) {
|
|
break label$6
|
|
}
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$2 = var$4 & var$2 | 0;
|
|
i64toi32_i32$3 = 0;
|
|
i64toi32_i32$0 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$3 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
$40 = 0;
|
|
} else {
|
|
i64toi32_i32$3 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$1 << i64toi32_i32$4 | 0) | 0;
|
|
$40 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
}
|
|
$63$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$1 = var$0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = -1;
|
|
i64toi32_i32$2 = i64toi32_i32$3 & i64toi32_i32$2 | 0;
|
|
$65 = i64toi32_i32$1 & i64toi32_i32$0 | 0;
|
|
$65$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = $63$hi;
|
|
i64toi32_i32$3 = $40;
|
|
i64toi32_i32$1 = $65$hi;
|
|
i64toi32_i32$0 = $65;
|
|
i64toi32_i32$1 = i64toi32_i32$2 | i64toi32_i32$1 | 0;
|
|
__wasm_intrinsics_temp_i64 = i64toi32_i32$3 | i64toi32_i32$0 | 0;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = var$2 >>> ((__wasm_ctz_i32(var$3 | 0) | 0) & 31 | 0) | 0;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
|
|
return i64toi32_i32$3 | 0;
|
|
}
|
|
}
|
|
var$4 = var$3 + -1 | 0;
|
|
if (!(var$4 & var$3 | 0)) {
|
|
break label$5
|
|
}
|
|
var$2 = (Math_clz32(var$3) + 33 | 0) - Math_clz32(var$2) | 0;
|
|
var$3 = 0 - var$2 | 0;
|
|
break label$3;
|
|
}
|
|
var$3 = 63 - var$2 | 0;
|
|
var$2 = var$2 + 1 | 0;
|
|
break label$3;
|
|
}
|
|
var$4 = (var$2 >>> 0) / (var$3 >>> 0) | 0;
|
|
i64toi32_i32$3 = 0;
|
|
i64toi32_i32$2 = var$2 - Math_imul(var$4, var$3) | 0;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
$41 = 0;
|
|
} else {
|
|
i64toi32_i32$1 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$3 << i64toi32_i32$4 | 0) | 0;
|
|
$41 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
}
|
|
__wasm_intrinsics_temp_i64 = $41;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$2 = var$4;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
|
|
return i64toi32_i32$2 | 0;
|
|
}
|
|
var$2 = Math_clz32(var$3) - Math_clz32(var$2) | 0;
|
|
if (var$2 >>> 0 < 31 >>> 0) {
|
|
break label$4
|
|
}
|
|
break label$2;
|
|
}
|
|
i64toi32_i32$2 = var$0$hi;
|
|
i64toi32_i32$2 = 0;
|
|
__wasm_intrinsics_temp_i64 = var$4 & var$0 | 0;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$2;
|
|
if ((var$3 | 0) == (1 | 0)) {
|
|
break label$1
|
|
}
|
|
i64toi32_i32$2 = var$0$hi;
|
|
i64toi32_i32$2 = 0;
|
|
$120$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$1 = $120$hi;
|
|
i64toi32_i32$0 = __wasm_ctz_i32(var$3 | 0) | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = 0;
|
|
$42 = i64toi32_i32$2 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$2 >>> i64toi32_i32$4 | 0;
|
|
$42 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$2 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$3 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
i64toi32_i32$3 = $42;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
|
|
return i64toi32_i32$3 | 0;
|
|
}
|
|
var$3 = 63 - var$2 | 0;
|
|
var$2 = var$2 + 1 | 0;
|
|
}
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$3 = 0;
|
|
$129$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$2 = var$0;
|
|
i64toi32_i32$1 = $129$hi;
|
|
i64toi32_i32$0 = var$2 & 63 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = 0;
|
|
$43 = i64toi32_i32$3 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$3 >>> i64toi32_i32$4 | 0;
|
|
$43 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$3 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$2 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$5 = $43;
|
|
var$5$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$1 = 0;
|
|
$134$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$2 = $134$hi;
|
|
i64toi32_i32$0 = var$3 & 63 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$3 << i64toi32_i32$4 | 0;
|
|
$44 = 0;
|
|
} else {
|
|
i64toi32_i32$2 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$3 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$1 << i64toi32_i32$4 | 0) | 0;
|
|
$44 = i64toi32_i32$3 << i64toi32_i32$4 | 0;
|
|
}
|
|
var$0 = $44;
|
|
var$0$hi = i64toi32_i32$2;
|
|
label$13 : {
|
|
if (var$2) {
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$1 = var$1;
|
|
i64toi32_i32$3 = -1;
|
|
i64toi32_i32$0 = -1;
|
|
i64toi32_i32$4 = i64toi32_i32$1 + i64toi32_i32$0 | 0;
|
|
i64toi32_i32$5 = i64toi32_i32$2 + i64toi32_i32$3 | 0;
|
|
if (i64toi32_i32$4 >>> 0 < i64toi32_i32$0 >>> 0) {
|
|
i64toi32_i32$5 = i64toi32_i32$5 + 1 | 0
|
|
}
|
|
var$8 = i64toi32_i32$4;
|
|
var$8$hi = i64toi32_i32$5;
|
|
label$15 : while (1) {
|
|
i64toi32_i32$5 = var$5$hi;
|
|
i64toi32_i32$2 = var$5;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$3 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$3 | 0;
|
|
$45 = 0;
|
|
} else {
|
|
i64toi32_i32$1 = ((1 << i64toi32_i32$3 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$3 | 0) | 0) | 0 | (i64toi32_i32$5 << i64toi32_i32$3 | 0) | 0;
|
|
$45 = i64toi32_i32$2 << i64toi32_i32$3 | 0;
|
|
}
|
|
$140 = $45;
|
|
$140$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = 63;
|
|
i64toi32_i32$3 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = 0;
|
|
$46 = i64toi32_i32$1 >>> i64toi32_i32$3 | 0;
|
|
} else {
|
|
i64toi32_i32$2 = i64toi32_i32$1 >>> i64toi32_i32$3 | 0;
|
|
$46 = (((1 << i64toi32_i32$3 | 0) - 1 | 0) & i64toi32_i32$1 | 0) << (32 - i64toi32_i32$3 | 0) | 0 | (i64toi32_i32$5 >>> i64toi32_i32$3 | 0) | 0;
|
|
}
|
|
$142$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = $140$hi;
|
|
i64toi32_i32$1 = $140;
|
|
i64toi32_i32$5 = $142$hi;
|
|
i64toi32_i32$0 = $46;
|
|
i64toi32_i32$5 = i64toi32_i32$2 | i64toi32_i32$5 | 0;
|
|
var$5 = i64toi32_i32$1 | i64toi32_i32$0 | 0;
|
|
var$5$hi = i64toi32_i32$5;
|
|
$144 = var$5;
|
|
$144$hi = i64toi32_i32$5;
|
|
i64toi32_i32$5 = var$8$hi;
|
|
i64toi32_i32$5 = var$5$hi;
|
|
i64toi32_i32$5 = var$8$hi;
|
|
i64toi32_i32$2 = var$8;
|
|
i64toi32_i32$1 = var$5$hi;
|
|
i64toi32_i32$0 = var$5;
|
|
i64toi32_i32$3 = i64toi32_i32$2 - i64toi32_i32$0 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$2 >>> 0 < i64toi32_i32$0 >>> 0;
|
|
i64toi32_i32$4 = i64toi32_i32$6 + i64toi32_i32$1 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$5 - i64toi32_i32$4 | 0;
|
|
i64toi32_i32$5 = i64toi32_i32$3;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = 63;
|
|
i64toi32_i32$1 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$4 >> 31 | 0;
|
|
$47 = i64toi32_i32$4 >> i64toi32_i32$1 | 0;
|
|
} else {
|
|
i64toi32_i32$2 = i64toi32_i32$4 >> i64toi32_i32$1 | 0;
|
|
$47 = (((1 << i64toi32_i32$1 | 0) - 1 | 0) & i64toi32_i32$4 | 0) << (32 - i64toi32_i32$1 | 0) | 0 | (i64toi32_i32$5 >>> i64toi32_i32$1 | 0) | 0;
|
|
}
|
|
var$6 = $47;
|
|
var$6$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$2 = var$6$hi;
|
|
i64toi32_i32$4 = var$6;
|
|
i64toi32_i32$5 = var$1$hi;
|
|
i64toi32_i32$0 = var$1;
|
|
i64toi32_i32$5 = i64toi32_i32$2 & i64toi32_i32$5 | 0;
|
|
$151 = i64toi32_i32$4 & i64toi32_i32$0 | 0;
|
|
$151$hi = i64toi32_i32$5;
|
|
i64toi32_i32$5 = $144$hi;
|
|
i64toi32_i32$2 = $144;
|
|
i64toi32_i32$4 = $151$hi;
|
|
i64toi32_i32$0 = $151;
|
|
i64toi32_i32$1 = i64toi32_i32$2 - i64toi32_i32$0 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$2 >>> 0 < i64toi32_i32$0 >>> 0;
|
|
i64toi32_i32$3 = i64toi32_i32$6 + i64toi32_i32$4 | 0;
|
|
i64toi32_i32$3 = i64toi32_i32$5 - i64toi32_i32$3 | 0;
|
|
var$5 = i64toi32_i32$1;
|
|
var$5$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$5 << i64toi32_i32$4 | 0;
|
|
$48 = 0;
|
|
} else {
|
|
i64toi32_i32$2 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$5 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$3 << i64toi32_i32$4 | 0) | 0;
|
|
$48 = i64toi32_i32$5 << i64toi32_i32$4 | 0;
|
|
}
|
|
$154$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = var$7$hi;
|
|
i64toi32_i32$2 = $154$hi;
|
|
i64toi32_i32$3 = $48;
|
|
i64toi32_i32$5 = var$7$hi;
|
|
i64toi32_i32$0 = var$7;
|
|
i64toi32_i32$5 = i64toi32_i32$2 | i64toi32_i32$5 | 0;
|
|
var$0 = i64toi32_i32$3 | i64toi32_i32$0 | 0;
|
|
var$0$hi = i64toi32_i32$5;
|
|
i64toi32_i32$5 = var$6$hi;
|
|
i64toi32_i32$2 = var$6;
|
|
i64toi32_i32$3 = 0;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$3 = i64toi32_i32$5 & i64toi32_i32$3 | 0;
|
|
var$6 = i64toi32_i32$2 & i64toi32_i32$0 | 0;
|
|
var$6$hi = i64toi32_i32$3;
|
|
var$7 = var$6;
|
|
var$7$hi = i64toi32_i32$3;
|
|
var$2 = var$2 + -1 | 0;
|
|
if (var$2) {
|
|
continue label$15
|
|
}
|
|
break label$15;
|
|
};
|
|
break label$13;
|
|
}
|
|
}
|
|
i64toi32_i32$3 = var$5$hi;
|
|
__wasm_intrinsics_temp_i64 = var$5;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$5 << i64toi32_i32$4 | 0;
|
|
$49 = 0;
|
|
} else {
|
|
i64toi32_i32$2 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$5 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$3 << i64toi32_i32$4 | 0) | 0;
|
|
$49 = i64toi32_i32$5 << i64toi32_i32$4 | 0;
|
|
}
|
|
$165$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = var$6$hi;
|
|
i64toi32_i32$2 = $165$hi;
|
|
i64toi32_i32$3 = $49;
|
|
i64toi32_i32$5 = var$6$hi;
|
|
i64toi32_i32$0 = var$6;
|
|
i64toi32_i32$5 = i64toi32_i32$2 | i64toi32_i32$5 | 0;
|
|
i64toi32_i32$3 = i64toi32_i32$3 | i64toi32_i32$0 | 0;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$5;
|
|
return i64toi32_i32$3 | 0;
|
|
}
|
|
i64toi32_i32$3 = var$0$hi;
|
|
__wasm_intrinsics_temp_i64 = var$0;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = 0;
|
|
var$0 = 0;
|
|
var$0$hi = i64toi32_i32$3;
|
|
}
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$3;
|
|
return i64toi32_i32$5 | 0;
|
|
}
|
|
|
|
function __wasm_i64_sdiv(var$0, var$0$hi, var$1, var$1$hi) {
|
|
var$0 = var$0 | 0;
|
|
var$0$hi = var$0$hi | 0;
|
|
var$1 = var$1 | 0;
|
|
var$1$hi = var$1$hi | 0;
|
|
var i64toi32_i32$0 = 0, i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$0 = var$1$hi;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$1 = var$1$hi;
|
|
i64toi32_i32$1 = _ZN17compiler_builtins3int4sdiv3Div3div17he78fc483e41d7ec7E(var$0 | 0, i64toi32_i32$0 | 0, var$1 | 0, i64toi32_i32$1 | 0) | 0;
|
|
i64toi32_i32$0 = i64toi32_i32$HIGH_BITS;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$0;
|
|
return i64toi32_i32$1 | 0;
|
|
}
|
|
|
|
function __wasm_i64_udiv(var$0, var$0$hi, var$1, var$1$hi) {
|
|
var$0 = var$0 | 0;
|
|
var$0$hi = var$0$hi | 0;
|
|
var$1 = var$1 | 0;
|
|
var$1$hi = var$1$hi | 0;
|
|
var i64toi32_i32$0 = 0, i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$0 = var$1$hi;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$1 = var$1$hi;
|
|
i64toi32_i32$1 = _ZN17compiler_builtins3int4udiv10divmod_u6417h6026910b5ed08e40E(var$0 | 0, i64toi32_i32$0 | 0, var$1 | 0, i64toi32_i32$1 | 0) | 0;
|
|
i64toi32_i32$0 = i64toi32_i32$HIGH_BITS;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$0;
|
|
return i64toi32_i32$1 | 0;
|
|
}
|
|
|
|
function __wasm_ctz_i32(var$0) {
|
|
var$0 = var$0 | 0;
|
|
if (var$0) {
|
|
return 31 - Math_clz32((var$0 + -1 | 0) ^ var$0 | 0) | 0 | 0
|
|
}
|
|
return 32 | 0;
|
|
}
|
|
|
|
return {
|
|
"no_dce_i32_div_s": $0,
|
|
"no_dce_i32_div_u": $1,
|
|
"no_dce_i64_div_s": legalstub$2,
|
|
"no_dce_i64_div_u": legalstub$3
|
|
};
|
|
}
|
|
|
|
var retasmFunc = asmFunc({
|
|
});
|
|
export var no_dce_i32_div_s = retasmFunc.no_dce_i32_div_s;
|
|
export var no_dce_i32_div_u = retasmFunc.no_dce_i32_div_u;
|
|
export var no_dce_i64_div_s = retasmFunc.no_dce_i64_div_s;
|
|
export var no_dce_i64_div_u = retasmFunc.no_dce_i64_div_u;
|
|
|
|
function asmFunc(imports) {
|
|
var Math_imul = Math.imul;
|
|
var Math_fround = Math.fround;
|
|
var Math_abs = Math.abs;
|
|
var Math_clz32 = Math.clz32;
|
|
var Math_min = Math.min;
|
|
var Math_max = Math.max;
|
|
var Math_floor = Math.floor;
|
|
var Math_ceil = Math.ceil;
|
|
var Math_trunc = Math.trunc;
|
|
var Math_sqrt = Math.sqrt;
|
|
var __wasm_intrinsics_temp_i64 = 0;
|
|
var __wasm_intrinsics_temp_i64$hi = 0;
|
|
var i64toi32_i32$HIGH_BITS = 0;
|
|
function $0(x, y) {
|
|
x = x | 0;
|
|
y = y | 0;
|
|
(x | 0) % (y | 0) | 0;
|
|
}
|
|
|
|
function $1(x, y) {
|
|
x = x | 0;
|
|
y = y | 0;
|
|
(x >>> 0) % (y >>> 0) | 0;
|
|
}
|
|
|
|
function $2(x, x$hi, y, y$hi) {
|
|
x = x | 0;
|
|
x$hi = x$hi | 0;
|
|
y = y | 0;
|
|
y$hi = y$hi | 0;
|
|
__wasm_i64_srem(x | 0, x$hi | 0, y | 0, y$hi | 0) | 0;
|
|
}
|
|
|
|
function $3(x, x$hi, y, y$hi) {
|
|
x = x | 0;
|
|
x$hi = x$hi | 0;
|
|
y = y | 0;
|
|
y$hi = y$hi | 0;
|
|
__wasm_i64_urem(x | 0, x$hi | 0, y | 0, y$hi | 0) | 0;
|
|
}
|
|
|
|
function legalstub$2($0_1, $1_1, $2_1, $3_1) {
|
|
$0_1 = $0_1 | 0;
|
|
$1_1 = $1_1 | 0;
|
|
$2_1 = $2_1 | 0;
|
|
$3_1 = $3_1 | 0;
|
|
var i64toi32_i32$2 = 0, i64toi32_i32$1 = 0, i64toi32_i32$0 = 0, i64toi32_i32$4 = 0, i64toi32_i32$3 = 0, $19 = 0, $20 = 0, $5 = 0, $5$hi = 0, $8$hi = 0, $9 = 0, $9$hi = 0, $11 = 0, $11$hi = 0, $14$hi = 0, $15 = 0, $15$hi = 0;
|
|
i64toi32_i32$0 = 0;
|
|
$5 = $0_1;
|
|
$5$hi = i64toi32_i32$0;
|
|
i64toi32_i32$0 = 0;
|
|
i64toi32_i32$2 = $1_1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
$19 = 0;
|
|
} else {
|
|
i64toi32_i32$1 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$0 << i64toi32_i32$4 | 0) | 0;
|
|
$19 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
}
|
|
$8$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = $5$hi;
|
|
i64toi32_i32$0 = $5;
|
|
i64toi32_i32$2 = $8$hi;
|
|
i64toi32_i32$3 = $19;
|
|
i64toi32_i32$2 = i64toi32_i32$1 | i64toi32_i32$2 | 0;
|
|
$9 = i64toi32_i32$0 | i64toi32_i32$3 | 0;
|
|
$9$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = 0;
|
|
$11 = $2_1;
|
|
$11$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$1 = $3_1;
|
|
i64toi32_i32$0 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$0 = i64toi32_i32$1 << i64toi32_i32$4 | 0;
|
|
$20 = 0;
|
|
} else {
|
|
i64toi32_i32$0 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$1 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$2 << i64toi32_i32$4 | 0) | 0;
|
|
$20 = i64toi32_i32$1 << i64toi32_i32$4 | 0;
|
|
}
|
|
$14$hi = i64toi32_i32$0;
|
|
i64toi32_i32$0 = $11$hi;
|
|
i64toi32_i32$2 = $11;
|
|
i64toi32_i32$1 = $14$hi;
|
|
i64toi32_i32$3 = $20;
|
|
i64toi32_i32$1 = i64toi32_i32$0 | i64toi32_i32$1 | 0;
|
|
$15 = i64toi32_i32$2 | i64toi32_i32$3 | 0;
|
|
$15$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = $9$hi;
|
|
i64toi32_i32$2 = $15$hi;
|
|
$2($9 | 0, i64toi32_i32$1 | 0, $15 | 0, i64toi32_i32$2 | 0);
|
|
}
|
|
|
|
function legalstub$3($0_1, $1_1, $2_1, $3_1) {
|
|
$0_1 = $0_1 | 0;
|
|
$1_1 = $1_1 | 0;
|
|
$2_1 = $2_1 | 0;
|
|
$3_1 = $3_1 | 0;
|
|
var i64toi32_i32$2 = 0, i64toi32_i32$1 = 0, i64toi32_i32$0 = 0, i64toi32_i32$4 = 0, i64toi32_i32$3 = 0, $19 = 0, $20 = 0, $5 = 0, $5$hi = 0, $8$hi = 0, $9 = 0, $9$hi = 0, $11 = 0, $11$hi = 0, $14$hi = 0, $15 = 0, $15$hi = 0;
|
|
i64toi32_i32$0 = 0;
|
|
$5 = $0_1;
|
|
$5$hi = i64toi32_i32$0;
|
|
i64toi32_i32$0 = 0;
|
|
i64toi32_i32$2 = $1_1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
$19 = 0;
|
|
} else {
|
|
i64toi32_i32$1 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$0 << i64toi32_i32$4 | 0) | 0;
|
|
$19 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
}
|
|
$8$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = $5$hi;
|
|
i64toi32_i32$0 = $5;
|
|
i64toi32_i32$2 = $8$hi;
|
|
i64toi32_i32$3 = $19;
|
|
i64toi32_i32$2 = i64toi32_i32$1 | i64toi32_i32$2 | 0;
|
|
$9 = i64toi32_i32$0 | i64toi32_i32$3 | 0;
|
|
$9$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = 0;
|
|
$11 = $2_1;
|
|
$11$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$1 = $3_1;
|
|
i64toi32_i32$0 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$0 = i64toi32_i32$1 << i64toi32_i32$4 | 0;
|
|
$20 = 0;
|
|
} else {
|
|
i64toi32_i32$0 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$1 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$2 << i64toi32_i32$4 | 0) | 0;
|
|
$20 = i64toi32_i32$1 << i64toi32_i32$4 | 0;
|
|
}
|
|
$14$hi = i64toi32_i32$0;
|
|
i64toi32_i32$0 = $11$hi;
|
|
i64toi32_i32$2 = $11;
|
|
i64toi32_i32$1 = $14$hi;
|
|
i64toi32_i32$3 = $20;
|
|
i64toi32_i32$1 = i64toi32_i32$0 | i64toi32_i32$1 | 0;
|
|
$15 = i64toi32_i32$2 | i64toi32_i32$3 | 0;
|
|
$15$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = $9$hi;
|
|
i64toi32_i32$2 = $15$hi;
|
|
$3($9 | 0, i64toi32_i32$1 | 0, $15 | 0, i64toi32_i32$2 | 0);
|
|
}
|
|
|
|
function _ZN17compiler_builtins3int4sdiv3Mod4mod_17h2cbb7bbf36e41d68E(var$0, var$0$hi, var$1, var$1$hi) {
|
|
var$0 = var$0 | 0;
|
|
var$0$hi = var$0$hi | 0;
|
|
var$1 = var$1 | 0;
|
|
var$1$hi = var$1$hi | 0;
|
|
var i64toi32_i32$1 = 0, i64toi32_i32$4 = 0, i64toi32_i32$2 = 0, i64toi32_i32$0 = 0, i64toi32_i32$3 = 0, i64toi32_i32$5 = 0, var$2$hi = 0, i64toi32_i32$6 = 0, var$2 = 0, $20 = 0, $21 = 0, $7$hi = 0, $9 = 0, $9$hi = 0, $14$hi = 0, $16$hi = 0, $17$hi = 0, $19$hi = 0;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$2 = var$0;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 63;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$0 >> 31 | 0;
|
|
$20 = i64toi32_i32$0 >> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$0 >> i64toi32_i32$4 | 0;
|
|
$20 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$0 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$2 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$2 = $20;
|
|
var$2$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$1 = var$2$hi;
|
|
i64toi32_i32$0 = var$2;
|
|
i64toi32_i32$2 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$2 = i64toi32_i32$1 ^ i64toi32_i32$2 | 0;
|
|
$7$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = i64toi32_i32$1;
|
|
i64toi32_i32$2 = $7$hi;
|
|
i64toi32_i32$1 = i64toi32_i32$0 ^ i64toi32_i32$3 | 0;
|
|
i64toi32_i32$0 = var$2$hi;
|
|
i64toi32_i32$3 = var$2;
|
|
i64toi32_i32$4 = i64toi32_i32$1 - i64toi32_i32$3 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$1 >>> 0 < i64toi32_i32$3 >>> 0;
|
|
i64toi32_i32$5 = i64toi32_i32$6 + i64toi32_i32$0 | 0;
|
|
i64toi32_i32$5 = i64toi32_i32$2 - i64toi32_i32$5 | 0;
|
|
$9 = i64toi32_i32$4;
|
|
$9$hi = i64toi32_i32$5;
|
|
i64toi32_i32$5 = var$1$hi;
|
|
i64toi32_i32$2 = var$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 63;
|
|
i64toi32_i32$0 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$5 >> 31 | 0;
|
|
$21 = i64toi32_i32$5 >> i64toi32_i32$0 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$5 >> i64toi32_i32$0 | 0;
|
|
$21 = (((1 << i64toi32_i32$0 | 0) - 1 | 0) & i64toi32_i32$5 | 0) << (32 - i64toi32_i32$0 | 0) | 0 | (i64toi32_i32$2 >>> i64toi32_i32$0 | 0) | 0;
|
|
}
|
|
var$0 = $21;
|
|
var$0$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$1$hi;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$3 = var$1;
|
|
i64toi32_i32$2 = i64toi32_i32$1 ^ i64toi32_i32$2 | 0;
|
|
$14$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = i64toi32_i32$1;
|
|
i64toi32_i32$2 = $14$hi;
|
|
i64toi32_i32$1 = i64toi32_i32$5 ^ i64toi32_i32$3 | 0;
|
|
i64toi32_i32$5 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$0 = i64toi32_i32$1 - i64toi32_i32$3 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$1 >>> 0 < i64toi32_i32$3 >>> 0;
|
|
i64toi32_i32$4 = i64toi32_i32$6 + i64toi32_i32$5 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$2 - i64toi32_i32$4 | 0;
|
|
$16$hi = i64toi32_i32$4;
|
|
i64toi32_i32$4 = $9$hi;
|
|
i64toi32_i32$1 = $16$hi;
|
|
i64toi32_i32$1 = __wasm_i64_urem($9 | 0, i64toi32_i32$4 | 0, i64toi32_i32$0 | 0, i64toi32_i32$1 | 0) | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$HIGH_BITS;
|
|
$17$hi = i64toi32_i32$4;
|
|
i64toi32_i32$4 = var$2$hi;
|
|
i64toi32_i32$4 = $17$hi;
|
|
i64toi32_i32$2 = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$2$hi;
|
|
i64toi32_i32$3 = var$2;
|
|
i64toi32_i32$1 = i64toi32_i32$4 ^ i64toi32_i32$1 | 0;
|
|
$19$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$2$hi;
|
|
i64toi32_i32$1 = $19$hi;
|
|
i64toi32_i32$4 = i64toi32_i32$2 ^ i64toi32_i32$3 | 0;
|
|
i64toi32_i32$2 = var$2$hi;
|
|
i64toi32_i32$5 = i64toi32_i32$4 - i64toi32_i32$3 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$4 >>> 0 < i64toi32_i32$3 >>> 0;
|
|
i64toi32_i32$0 = i64toi32_i32$6 + i64toi32_i32$2 | 0;
|
|
i64toi32_i32$0 = i64toi32_i32$1 - i64toi32_i32$0 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$5;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$0;
|
|
return i64toi32_i32$4 | 0;
|
|
}
|
|
|
|
function _ZN17compiler_builtins3int4udiv10divmod_u6417h6026910b5ed08e40E(var$0, var$0$hi, var$1, var$1$hi) {
|
|
var$0 = var$0 | 0;
|
|
var$0$hi = var$0$hi | 0;
|
|
var$1 = var$1 | 0;
|
|
var$1$hi = var$1$hi | 0;
|
|
var i64toi32_i32$2 = 0, i64toi32_i32$3 = 0, i64toi32_i32$4 = 0, i64toi32_i32$1 = 0, i64toi32_i32$0 = 0, i64toi32_i32$5 = 0, var$2 = 0, var$3 = 0, var$4 = 0, var$5 = 0, var$5$hi = 0, var$6 = 0, var$6$hi = 0, i64toi32_i32$6 = 0, $37 = 0, $38 = 0, $39 = 0, $40 = 0, $41 = 0, $42 = 0, $43 = 0, $44 = 0, var$8$hi = 0, $45 = 0, $46 = 0, $47 = 0, $48 = 0, var$7$hi = 0, $49 = 0, $63$hi = 0, $65 = 0, $65$hi = 0, $120$hi = 0, $129$hi = 0, $134$hi = 0, var$8 = 0, $140 = 0, $140$hi = 0, $142$hi = 0, $144 = 0, $144$hi = 0, $151 = 0, $151$hi = 0, $154$hi = 0, var$7 = 0, $165$hi = 0;
|
|
label$1 : {
|
|
label$2 : {
|
|
label$3 : {
|
|
label$4 : {
|
|
label$5 : {
|
|
label$6 : {
|
|
label$7 : {
|
|
label$8 : {
|
|
label$9 : {
|
|
label$10 : {
|
|
label$11 : {
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$2 = var$0;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = 0;
|
|
$37 = i64toi32_i32$0 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$0 >>> i64toi32_i32$4 | 0;
|
|
$37 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$0 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$2 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$2 = $37;
|
|
if (var$2) {
|
|
i64toi32_i32$1 = var$1$hi;
|
|
var$3 = var$1;
|
|
if (!var$3) {
|
|
break label$11
|
|
}
|
|
i64toi32_i32$0 = var$3;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$3 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = 0;
|
|
$38 = i64toi32_i32$1 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$2 = i64toi32_i32$1 >>> i64toi32_i32$4 | 0;
|
|
$38 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$1 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$0 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$4 = $38;
|
|
if (!var$4) {
|
|
break label$9
|
|
}
|
|
var$2 = Math_clz32(var$4) - Math_clz32(var$2) | 0;
|
|
if (var$2 >>> 0 <= 31 >>> 0) {
|
|
break label$8
|
|
}
|
|
break label$2;
|
|
}
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$1 = var$1;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$3 = 0;
|
|
if (i64toi32_i32$2 >>> 0 > i64toi32_i32$0 >>> 0 | ((i64toi32_i32$2 | 0) == (i64toi32_i32$0 | 0) & i64toi32_i32$1 >>> 0 >= i64toi32_i32$3 >>> 0 | 0) | 0) {
|
|
break label$2
|
|
}
|
|
i64toi32_i32$1 = var$0$hi;
|
|
var$2 = var$0;
|
|
i64toi32_i32$1 = i64toi32_i32$2;
|
|
i64toi32_i32$1 = i64toi32_i32$2;
|
|
var$3 = var$1;
|
|
var$2 = (var$2 >>> 0) / (var$3 >>> 0) | 0;
|
|
i64toi32_i32$1 = 0;
|
|
__wasm_intrinsics_temp_i64 = var$0 - Math_imul(var$2, var$3) | 0;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$2 = var$2;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
|
|
return i64toi32_i32$2 | 0;
|
|
}
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$3 = var$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = 0;
|
|
$39 = i64toi32_i32$2 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$2 >>> i64toi32_i32$4 | 0;
|
|
$39 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$2 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$3 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$3 = $39;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
if (!var$0) {
|
|
break label$7
|
|
}
|
|
if (!var$3) {
|
|
break label$6
|
|
}
|
|
var$4 = var$3 + -1 | 0;
|
|
if (var$4 & var$3 | 0) {
|
|
break label$6
|
|
}
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$2 = var$4 & var$2 | 0;
|
|
i64toi32_i32$3 = 0;
|
|
i64toi32_i32$0 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$3 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
$40 = 0;
|
|
} else {
|
|
i64toi32_i32$3 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$1 << i64toi32_i32$4 | 0) | 0;
|
|
$40 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
}
|
|
$63$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$1 = var$0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = -1;
|
|
i64toi32_i32$2 = i64toi32_i32$3 & i64toi32_i32$2 | 0;
|
|
$65 = i64toi32_i32$1 & i64toi32_i32$0 | 0;
|
|
$65$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = $63$hi;
|
|
i64toi32_i32$3 = $40;
|
|
i64toi32_i32$1 = $65$hi;
|
|
i64toi32_i32$0 = $65;
|
|
i64toi32_i32$1 = i64toi32_i32$2 | i64toi32_i32$1 | 0;
|
|
__wasm_intrinsics_temp_i64 = i64toi32_i32$3 | i64toi32_i32$0 | 0;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$3 = var$2 >>> ((__wasm_ctz_i32(var$3 | 0) | 0) & 31 | 0) | 0;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
|
|
return i64toi32_i32$3 | 0;
|
|
}
|
|
}
|
|
var$4 = var$3 + -1 | 0;
|
|
if (!(var$4 & var$3 | 0)) {
|
|
break label$5
|
|
}
|
|
var$2 = (Math_clz32(var$3) + 33 | 0) - Math_clz32(var$2) | 0;
|
|
var$3 = 0 - var$2 | 0;
|
|
break label$3;
|
|
}
|
|
var$3 = 63 - var$2 | 0;
|
|
var$2 = var$2 + 1 | 0;
|
|
break label$3;
|
|
}
|
|
var$4 = (var$2 >>> 0) / (var$3 >>> 0) | 0;
|
|
i64toi32_i32$3 = 0;
|
|
i64toi32_i32$2 = var$2 - Math_imul(var$4, var$3) | 0;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = 32;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
$41 = 0;
|
|
} else {
|
|
i64toi32_i32$1 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$3 << i64toi32_i32$4 | 0) | 0;
|
|
$41 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
|
|
}
|
|
__wasm_intrinsics_temp_i64 = $41;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$2 = var$4;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
|
|
return i64toi32_i32$2 | 0;
|
|
}
|
|
var$2 = Math_clz32(var$3) - Math_clz32(var$2) | 0;
|
|
if (var$2 >>> 0 < 31 >>> 0) {
|
|
break label$4
|
|
}
|
|
break label$2;
|
|
}
|
|
i64toi32_i32$2 = var$0$hi;
|
|
i64toi32_i32$2 = 0;
|
|
__wasm_intrinsics_temp_i64 = var$4 & var$0 | 0;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$2;
|
|
if ((var$3 | 0) == (1 | 0)) {
|
|
break label$1
|
|
}
|
|
i64toi32_i32$2 = var$0$hi;
|
|
i64toi32_i32$2 = 0;
|
|
$120$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$1 = $120$hi;
|
|
i64toi32_i32$0 = __wasm_ctz_i32(var$3 | 0) | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = 0;
|
|
$42 = i64toi32_i32$2 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$2 >>> i64toi32_i32$4 | 0;
|
|
$42 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$2 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$3 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
i64toi32_i32$3 = $42;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
|
|
return i64toi32_i32$3 | 0;
|
|
}
|
|
var$3 = 63 - var$2 | 0;
|
|
var$2 = var$2 + 1 | 0;
|
|
}
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$3 = 0;
|
|
$129$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$2 = var$0;
|
|
i64toi32_i32$1 = $129$hi;
|
|
i64toi32_i32$0 = var$2 & 63 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = 0;
|
|
$43 = i64toi32_i32$3 >>> i64toi32_i32$4 | 0;
|
|
} else {
|
|
i64toi32_i32$1 = i64toi32_i32$3 >>> i64toi32_i32$4 | 0;
|
|
$43 = (((1 << i64toi32_i32$4 | 0) - 1 | 0) & i64toi32_i32$3 | 0) << (32 - i64toi32_i32$4 | 0) | 0 | (i64toi32_i32$2 >>> i64toi32_i32$4 | 0) | 0;
|
|
}
|
|
var$5 = $43;
|
|
var$5$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$1 = 0;
|
|
$134$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$3 = var$0;
|
|
i64toi32_i32$2 = $134$hi;
|
|
i64toi32_i32$0 = var$3 & 63 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$3 << i64toi32_i32$4 | 0;
|
|
$44 = 0;
|
|
} else {
|
|
i64toi32_i32$2 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$3 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$1 << i64toi32_i32$4 | 0) | 0;
|
|
$44 = i64toi32_i32$3 << i64toi32_i32$4 | 0;
|
|
}
|
|
var$0 = $44;
|
|
var$0$hi = i64toi32_i32$2;
|
|
label$13 : {
|
|
if (var$2) {
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$1 = var$1;
|
|
i64toi32_i32$3 = -1;
|
|
i64toi32_i32$0 = -1;
|
|
i64toi32_i32$4 = i64toi32_i32$1 + i64toi32_i32$0 | 0;
|
|
i64toi32_i32$5 = i64toi32_i32$2 + i64toi32_i32$3 | 0;
|
|
if (i64toi32_i32$4 >>> 0 < i64toi32_i32$0 >>> 0) {
|
|
i64toi32_i32$5 = i64toi32_i32$5 + 1 | 0
|
|
}
|
|
var$8 = i64toi32_i32$4;
|
|
var$8$hi = i64toi32_i32$5;
|
|
label$15 : while (1) {
|
|
i64toi32_i32$5 = var$5$hi;
|
|
i64toi32_i32$2 = var$5;
|
|
i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$3 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$3 | 0;
|
|
$45 = 0;
|
|
} else {
|
|
i64toi32_i32$1 = ((1 << i64toi32_i32$3 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$3 | 0) | 0) | 0 | (i64toi32_i32$5 << i64toi32_i32$3 | 0) | 0;
|
|
$45 = i64toi32_i32$2 << i64toi32_i32$3 | 0;
|
|
}
|
|
$140 = $45;
|
|
$140$hi = i64toi32_i32$1;
|
|
i64toi32_i32$1 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = 63;
|
|
i64toi32_i32$3 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = 0;
|
|
$46 = i64toi32_i32$1 >>> i64toi32_i32$3 | 0;
|
|
} else {
|
|
i64toi32_i32$2 = i64toi32_i32$1 >>> i64toi32_i32$3 | 0;
|
|
$46 = (((1 << i64toi32_i32$3 | 0) - 1 | 0) & i64toi32_i32$1 | 0) << (32 - i64toi32_i32$3 | 0) | 0 | (i64toi32_i32$5 >>> i64toi32_i32$3 | 0) | 0;
|
|
}
|
|
$142$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = $140$hi;
|
|
i64toi32_i32$1 = $140;
|
|
i64toi32_i32$5 = $142$hi;
|
|
i64toi32_i32$0 = $46;
|
|
i64toi32_i32$5 = i64toi32_i32$2 | i64toi32_i32$5 | 0;
|
|
var$5 = i64toi32_i32$1 | i64toi32_i32$0 | 0;
|
|
var$5$hi = i64toi32_i32$5;
|
|
$144 = var$5;
|
|
$144$hi = i64toi32_i32$5;
|
|
i64toi32_i32$5 = var$8$hi;
|
|
i64toi32_i32$5 = var$5$hi;
|
|
i64toi32_i32$5 = var$8$hi;
|
|
i64toi32_i32$2 = var$8;
|
|
i64toi32_i32$1 = var$5$hi;
|
|
i64toi32_i32$0 = var$5;
|
|
i64toi32_i32$3 = i64toi32_i32$2 - i64toi32_i32$0 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$2 >>> 0 < i64toi32_i32$0 >>> 0;
|
|
i64toi32_i32$4 = i64toi32_i32$6 + i64toi32_i32$1 | 0;
|
|
i64toi32_i32$4 = i64toi32_i32$5 - i64toi32_i32$4 | 0;
|
|
i64toi32_i32$5 = i64toi32_i32$3;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = 63;
|
|
i64toi32_i32$1 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$4 >> 31 | 0;
|
|
$47 = i64toi32_i32$4 >> i64toi32_i32$1 | 0;
|
|
} else {
|
|
i64toi32_i32$2 = i64toi32_i32$4 >> i64toi32_i32$1 | 0;
|
|
$47 = (((1 << i64toi32_i32$1 | 0) - 1 | 0) & i64toi32_i32$4 | 0) << (32 - i64toi32_i32$1 | 0) | 0 | (i64toi32_i32$5 >>> i64toi32_i32$1 | 0) | 0;
|
|
}
|
|
var$6 = $47;
|
|
var$6$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = var$1$hi;
|
|
i64toi32_i32$2 = var$6$hi;
|
|
i64toi32_i32$4 = var$6;
|
|
i64toi32_i32$5 = var$1$hi;
|
|
i64toi32_i32$0 = var$1;
|
|
i64toi32_i32$5 = i64toi32_i32$2 & i64toi32_i32$5 | 0;
|
|
$151 = i64toi32_i32$4 & i64toi32_i32$0 | 0;
|
|
$151$hi = i64toi32_i32$5;
|
|
i64toi32_i32$5 = $144$hi;
|
|
i64toi32_i32$2 = $144;
|
|
i64toi32_i32$4 = $151$hi;
|
|
i64toi32_i32$0 = $151;
|
|
i64toi32_i32$1 = i64toi32_i32$2 - i64toi32_i32$0 | 0;
|
|
i64toi32_i32$6 = i64toi32_i32$2 >>> 0 < i64toi32_i32$0 >>> 0;
|
|
i64toi32_i32$3 = i64toi32_i32$6 + i64toi32_i32$4 | 0;
|
|
i64toi32_i32$3 = i64toi32_i32$5 - i64toi32_i32$3 | 0;
|
|
var$5 = i64toi32_i32$1;
|
|
var$5$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$5 << i64toi32_i32$4 | 0;
|
|
$48 = 0;
|
|
} else {
|
|
i64toi32_i32$2 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$5 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$3 << i64toi32_i32$4 | 0) | 0;
|
|
$48 = i64toi32_i32$5 << i64toi32_i32$4 | 0;
|
|
}
|
|
$154$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = var$7$hi;
|
|
i64toi32_i32$2 = $154$hi;
|
|
i64toi32_i32$3 = $48;
|
|
i64toi32_i32$5 = var$7$hi;
|
|
i64toi32_i32$0 = var$7;
|
|
i64toi32_i32$5 = i64toi32_i32$2 | i64toi32_i32$5 | 0;
|
|
var$0 = i64toi32_i32$3 | i64toi32_i32$0 | 0;
|
|
var$0$hi = i64toi32_i32$5;
|
|
i64toi32_i32$5 = var$6$hi;
|
|
i64toi32_i32$2 = var$6;
|
|
i64toi32_i32$3 = 0;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$3 = i64toi32_i32$5 & i64toi32_i32$3 | 0;
|
|
var$6 = i64toi32_i32$2 & i64toi32_i32$0 | 0;
|
|
var$6$hi = i64toi32_i32$3;
|
|
var$7 = var$6;
|
|
var$7$hi = i64toi32_i32$3;
|
|
var$2 = var$2 + -1 | 0;
|
|
if (var$2) {
|
|
continue label$15
|
|
}
|
|
break label$15;
|
|
};
|
|
break label$13;
|
|
}
|
|
}
|
|
i64toi32_i32$3 = var$5$hi;
|
|
__wasm_intrinsics_temp_i64 = var$5;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$2 = 0;
|
|
i64toi32_i32$0 = 1;
|
|
i64toi32_i32$4 = i64toi32_i32$0 & 31 | 0;
|
|
if (32 >>> 0 <= (i64toi32_i32$0 & 63 | 0) >>> 0) {
|
|
i64toi32_i32$2 = i64toi32_i32$5 << i64toi32_i32$4 | 0;
|
|
$49 = 0;
|
|
} else {
|
|
i64toi32_i32$2 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$5 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$3 << i64toi32_i32$4 | 0) | 0;
|
|
$49 = i64toi32_i32$5 << i64toi32_i32$4 | 0;
|
|
}
|
|
$165$hi = i64toi32_i32$2;
|
|
i64toi32_i32$2 = var$6$hi;
|
|
i64toi32_i32$2 = $165$hi;
|
|
i64toi32_i32$3 = $49;
|
|
i64toi32_i32$5 = var$6$hi;
|
|
i64toi32_i32$0 = var$6;
|
|
i64toi32_i32$5 = i64toi32_i32$2 | i64toi32_i32$5 | 0;
|
|
i64toi32_i32$3 = i64toi32_i32$3 | i64toi32_i32$0 | 0;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$5;
|
|
return i64toi32_i32$3 | 0;
|
|
}
|
|
i64toi32_i32$3 = var$0$hi;
|
|
__wasm_intrinsics_temp_i64 = var$0;
|
|
__wasm_intrinsics_temp_i64$hi = i64toi32_i32$3;
|
|
i64toi32_i32$3 = 0;
|
|
var$0 = 0;
|
|
var$0$hi = i64toi32_i32$3;
|
|
}
|
|
i64toi32_i32$3 = var$0$hi;
|
|
i64toi32_i32$5 = var$0;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$3;
|
|
return i64toi32_i32$5 | 0;
|
|
}
|
|
|
|
function __wasm_i64_srem(var$0, var$0$hi, var$1, var$1$hi) {
|
|
var$0 = var$0 | 0;
|
|
var$0$hi = var$0$hi | 0;
|
|
var$1 = var$1 | 0;
|
|
var$1$hi = var$1$hi | 0;
|
|
var i64toi32_i32$0 = 0, i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$0 = var$1$hi;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$1 = var$1$hi;
|
|
i64toi32_i32$1 = _ZN17compiler_builtins3int4sdiv3Mod4mod_17h2cbb7bbf36e41d68E(var$0 | 0, i64toi32_i32$0 | 0, var$1 | 0, i64toi32_i32$1 | 0) | 0;
|
|
i64toi32_i32$0 = i64toi32_i32$HIGH_BITS;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$0;
|
|
return i64toi32_i32$1 | 0;
|
|
}
|
|
|
|
function __wasm_i64_urem(var$0, var$0$hi, var$1, var$1$hi) {
|
|
var$0 = var$0 | 0;
|
|
var$0$hi = var$0$hi | 0;
|
|
var$1 = var$1 | 0;
|
|
var$1$hi = var$1$hi | 0;
|
|
var i64toi32_i32$0 = 0, i64toi32_i32$1 = 0;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$0 = var$1$hi;
|
|
i64toi32_i32$0 = var$0$hi;
|
|
i64toi32_i32$1 = var$1$hi;
|
|
i64toi32_i32$1 = _ZN17compiler_builtins3int4udiv10divmod_u6417h6026910b5ed08e40E(var$0 | 0, i64toi32_i32$0 | 0, var$1 | 0, i64toi32_i32$1 | 0) | 0;
|
|
i64toi32_i32$0 = i64toi32_i32$HIGH_BITS;
|
|
i64toi32_i32$0 = __wasm_intrinsics_temp_i64$hi;
|
|
i64toi32_i32$1 = __wasm_intrinsics_temp_i64;
|
|
i64toi32_i32$HIGH_BITS = i64toi32_i32$0;
|
|
return i64toi32_i32$1 | 0;
|
|
}
|
|
|
|
function __wasm_ctz_i32(var$0) {
|
|
var$0 = var$0 | 0;
|
|
if (var$0) {
|
|
return 31 - Math_clz32((var$0 + -1 | 0) ^ var$0 | 0) | 0 | 0
|
|
}
|
|
return 32 | 0;
|
|
}
|
|
|
|
return {
|
|
"no_dce_i32_rem_s": $0,
|
|
"no_dce_i32_rem_u": $1,
|
|
"no_dce_i64_rem_s": legalstub$2,
|
|
"no_dce_i64_rem_u": legalstub$3
|
|
};
|
|
}
|
|
|
|
var retasmFunc = asmFunc({
|
|
});
|
|
export var no_dce_i32_rem_s = retasmFunc.no_dce_i32_rem_s;
|
|
export var no_dce_i32_rem_u = retasmFunc.no_dce_i32_rem_u;
|
|
export var no_dce_i64_rem_s = retasmFunc.no_dce_i64_rem_s;
|
|
export var no_dce_i64_rem_u = retasmFunc.no_dce_i64_rem_u;
|
|
|
|
function asmFunc(imports) {
|
|
var Math_imul = Math.imul;
|
|
var Math_fround = Math.fround;
|
|
var Math_abs = Math.abs;
|
|
var Math_clz32 = Math.clz32;
|
|
var Math_min = Math.min;
|
|
var Math_max = Math.max;
|
|
var Math_floor = Math.floor;
|
|
var Math_ceil = Math.ceil;
|
|
var Math_trunc = Math.trunc;
|
|
var Math_sqrt = Math.sqrt;
|
|
function $0(x) {
|
|
x = Math_fround(x);
|
|
~~x;
|
|
}
|
|
|
|
function $1(x) {
|
|
x = Math_fround(x);
|
|
~~x >>> 0;
|
|
}
|
|
|
|
function $2(x) {
|
|
x = +x;
|
|
~~x;
|
|
}
|
|
|
|
function $3(x) {
|
|
x = +x;
|
|
~~x >>> 0;
|
|
}
|
|
|
|
function $4(x) {
|
|
x = Math_fround(x);
|
|
var i64toi32_i32$0 = Math_fround(0), $2_1 = 0, $3_1 = 0;
|
|
i64toi32_i32$0 = x;
|
|
if (Math_fround(Math_abs(i64toi32_i32$0)) >= Math_fround(1.0)) {
|
|
if (i64toi32_i32$0 > Math_fround(0.0)) {
|
|
$2_1 = ~~Math_fround(Math_min(Math_fround(Math_floor(Math_fround(i64toi32_i32$0 / Math_fround(4294967296.0)))), Math_fround(Math_fround(4294967296.0) - Math_fround(1.0)))) >>> 0
|
|
} else {
|
|
$2_1 = ~~Math_fround(Math_ceil(Math_fround(Math_fround(i64toi32_i32$0 - Math_fround(~~i64toi32_i32$0 >>> 0 >>> 0)) / Math_fround(4294967296.0)))) >>> 0
|
|
}
|
|
$3_1 = $2_1;
|
|
} else {
|
|
$3_1 = 0
|
|
}
|
|
~~i64toi32_i32$0 >>> 0;
|
|
}
|
|
|
|
function $5(x) {
|
|
x = Math_fround(x);
|
|
var i64toi32_i32$0 = Math_fround(0), $2_1 = 0, $3_1 = 0;
|
|
i64toi32_i32$0 = x;
|
|
if (Math_fround(Math_abs(i64toi32_i32$0)) >= Math_fround(1.0)) {
|
|
if (i64toi32_i32$0 > Math_fround(0.0)) {
|
|
$2_1 = ~~Math_fround(Math_min(Math_fround(Math_floor(Math_fround(i64toi32_i32$0 / Math_fround(4294967296.0)))), Math_fround(Math_fround(4294967296.0) - Math_fround(1.0)))) >>> 0
|
|
} else {
|
|
$2_1 = ~~Math_fround(Math_ceil(Math_fround(Math_fround(i64toi32_i32$0 - Math_fround(~~i64toi32_i32$0 >>> 0 >>> 0)) / Math_fround(4294967296.0)))) >>> 0
|
|
}
|
|
$3_1 = $2_1;
|
|
} else {
|
|
$3_1 = 0
|
|
}
|
|
~~i64toi32_i32$0 >>> 0;
|
|
}
|
|
|
|
function $6(x) {
|
|
x = +x;
|
|
var i64toi32_i32$0 = 0.0, $2_1 = 0, $3_1 = 0;
|
|
i64toi32_i32$0 = x;
|
|
if (Math_abs(i64toi32_i32$0) >= 1.0) {
|
|
if (i64toi32_i32$0 > 0.0) {
|
|
$2_1 = ~~Math_min(Math_floor(i64toi32_i32$0 / 4294967296.0), 4294967296.0 - 1.0) >>> 0
|
|
} else {
|
|
$2_1 = ~~Math_ceil((i64toi32_i32$0 - +(~~i64toi32_i32$0 >>> 0 >>> 0)) / 4294967296.0) >>> 0
|
|
}
|
|
$3_1 = $2_1;
|
|
} else {
|
|
$3_1 = 0
|
|
}
|
|
~~i64toi32_i32$0 >>> 0;
|
|
}
|
|
|
|
function $7(x) {
|
|
x = +x;
|
|
var i64toi32_i32$0 = 0.0, $2_1 = 0, $3_1 = 0;
|
|
i64toi32_i32$0 = x;
|
|
if (Math_abs(i64toi32_i32$0) >= 1.0) {
|
|
if (i64toi32_i32$0 > 0.0) {
|
|
$2_1 = ~~Math_min(Math_floor(i64toi32_i32$0 / 4294967296.0), 4294967296.0 - 1.0) >>> 0
|
|
} else {
|
|
$2_1 = ~~Math_ceil((i64toi32_i32$0 - +(~~i64toi32_i32$0 >>> 0 >>> 0)) / 4294967296.0) >>> 0
|
|
}
|
|
$3_1 = $2_1;
|
|
} else {
|
|
$3_1 = 0
|
|
}
|
|
~~i64toi32_i32$0 >>> 0;
|
|
}
|
|
|
|
return {
|
|
"no_dce_i32_trunc_f32_s": $0,
|
|
"no_dce_i32_trunc_f32_u": $1,
|
|
"no_dce_i32_trunc_f64_s": $2,
|
|
"no_dce_i32_trunc_f64_u": $3,
|
|
"no_dce_i64_trunc_f32_s": $4,
|
|
"no_dce_i64_trunc_f32_u": $5,
|
|
"no_dce_i64_trunc_f64_s": $6,
|
|
"no_dce_i64_trunc_f64_u": $7
|
|
};
|
|
}
|
|
|
|
var retasmFunc = asmFunc({
|
|
});
|
|
export var no_dce_i32_trunc_f32_s = retasmFunc.no_dce_i32_trunc_f32_s;
|
|
export var no_dce_i32_trunc_f32_u = retasmFunc.no_dce_i32_trunc_f32_u;
|
|
export var no_dce_i32_trunc_f64_s = retasmFunc.no_dce_i32_trunc_f64_s;
|
|
export var no_dce_i32_trunc_f64_u = retasmFunc.no_dce_i32_trunc_f64_u;
|
|
export var no_dce_i64_trunc_f32_s = retasmFunc.no_dce_i64_trunc_f32_s;
|
|
export var no_dce_i64_trunc_f32_u = retasmFunc.no_dce_i64_trunc_f32_u;
|
|
export var no_dce_i64_trunc_f64_s = retasmFunc.no_dce_i64_trunc_f64_s;
|
|
export var no_dce_i64_trunc_f64_u = retasmFunc.no_dce_i64_trunc_f64_u;
|
|
|
|
function asmFunc(imports) {
|
|
var buffer = new ArrayBuffer(65536);
|
|
var HEAP8 = new Int8Array(buffer);
|
|
var HEAP16 = new Int16Array(buffer);
|
|
var HEAP32 = new Int32Array(buffer);
|
|
var HEAPU8 = new Uint8Array(buffer);
|
|
var HEAPU16 = new Uint16Array(buffer);
|
|
var HEAPU32 = new Uint32Array(buffer);
|
|
var HEAPF32 = new Float32Array(buffer);
|
|
var HEAPF64 = new Float64Array(buffer);
|
|
var Math_imul = Math.imul;
|
|
var Math_fround = Math.fround;
|
|
var Math_abs = Math.abs;
|
|
var Math_clz32 = Math.clz32;
|
|
var Math_min = Math.min;
|
|
var Math_max = Math.max;
|
|
var Math_floor = Math.floor;
|
|
var Math_ceil = Math.ceil;
|
|
var Math_trunc = Math.trunc;
|
|
var Math_sqrt = Math.sqrt;
|
|
function $0(i) {
|
|
i = i | 0;
|
|
HEAP32[i >> 2] | 0;
|
|
}
|
|
|
|
function $1(i) {
|
|
i = i | 0;
|
|
HEAP16[i >> 1] | 0;
|
|
}
|
|
|
|
function $2(i) {
|
|
i = i | 0;
|
|
HEAPU16[i >> 1] | 0;
|
|
}
|
|
|
|
function $3(i) {
|
|
i = i | 0;
|
|
HEAP8[i >> 0] | 0;
|
|
}
|
|
|
|
function $4(i) {
|
|
i = i | 0;
|
|
HEAPU8[i >> 0] | 0;
|
|
}
|
|
|
|
function $5(i) {
|
|
i = i | 0;
|
|
var i64toi32_i32$2 = 0;
|
|
i64toi32_i32$2 = i;
|
|
HEAP32[(i64toi32_i32$2 + 4 | 0) >> 2] | 0;
|
|
HEAP32[i64toi32_i32$2 >> 2] | 0;
|
|
}
|
|
|
|
function $6(i) {
|
|
i = i | 0;
|
|
var i64toi32_i32$0 = 0;
|
|
i64toi32_i32$0 = HEAP32[i >> 2] | 0;
|
|
}
|
|
|
|
function $7(i) {
|
|
i = i | 0;
|
|
HEAP32[i >> 2] | 0;
|
|
}
|
|
|
|
function $8(i) {
|
|
i = i | 0;
|
|
var i64toi32_i32$0 = 0;
|
|
i64toi32_i32$0 = HEAP16[i >> 1] | 0;
|
|
}
|
|
|
|
function $9(i) {
|
|
i = i | 0;
|
|
HEAPU16[i >> 1] | 0;
|
|
}
|
|
|
|
function $10(i) {
|
|
i = i | 0;
|
|
var i64toi32_i32$0 = 0;
|
|
i64toi32_i32$0 = HEAP8[i >> 0] | 0;
|
|
}
|
|
|
|
function $11(i) {
|
|
i = i | 0;
|
|
HEAPU8[i >> 0] | 0;
|
|
}
|
|
|
|
function $12(i) {
|
|
i = i | 0;
|
|
Math_fround(HEAPF32[i >> 2]);
|
|
}
|
|
|
|
function $13(i) {
|
|
i = i | 0;
|
|
+HEAPF64[i >> 3];
|
|
}
|
|
|
|
function __wasm_memory_size() {
|
|
return buffer.byteLength / 65536 | 0;
|
|
}
|
|
|
|
function __wasm_memory_grow(pagesToAdd) {
|
|
pagesToAdd = pagesToAdd | 0;
|
|
var oldPages = __wasm_memory_size() | 0;
|
|
var newPages = oldPages + pagesToAdd | 0;
|
|
if ((oldPages < newPages) && (newPages < 65536)) {
|
|
var newBuffer = new ArrayBuffer(Math_imul(newPages, 65536));
|
|
var newHEAP8 = new Int8Array(newBuffer);
|
|
newHEAP8.set(HEAP8);
|
|
HEAP8 = new Int8Array(newBuffer);
|
|
HEAP16 = new Int16Array(newBuffer);
|
|
HEAP32 = new Int32Array(newBuffer);
|
|
HEAPU8 = new Uint8Array(newBuffer);
|
|
HEAPU16 = new Uint16Array(newBuffer);
|
|
HEAPU32 = new Uint32Array(newBuffer);
|
|
HEAPF32 = new Float32Array(newBuffer);
|
|
HEAPF64 = new Float64Array(newBuffer);
|
|
buffer = newBuffer;
|
|
}
|
|
return oldPages;
|
|
}
|
|
|
|
return {
|
|
"no_dce_i32_load": $0,
|
|
"no_dce_i32_load16_s": $1,
|
|
"no_dce_i32_load16_u": $2,
|
|
"no_dce_i32_load8_s": $3,
|
|
"no_dce_i32_load8_u": $4,
|
|
"no_dce_i64_load": $5,
|
|
"no_dce_i64_load32_s": $6,
|
|
"no_dce_i64_load32_u": $7,
|
|
"no_dce_i64_load16_s": $8,
|
|
"no_dce_i64_load16_u": $9,
|
|
"no_dce_i64_load8_s": $10,
|
|
"no_dce_i64_load8_u": $11,
|
|
"no_dce_f32_load": $12,
|
|
"no_dce_f64_load": $13
|
|
};
|
|
}
|
|
|
|
var retasmFunc = asmFunc({
|
|
});
|
|
export var no_dce_i32_load = retasmFunc.no_dce_i32_load;
|
|
export var no_dce_i32_load16_s = retasmFunc.no_dce_i32_load16_s;
|
|
export var no_dce_i32_load16_u = retasmFunc.no_dce_i32_load16_u;
|
|
export var no_dce_i32_load8_s = retasmFunc.no_dce_i32_load8_s;
|
|
export var no_dce_i32_load8_u = retasmFunc.no_dce_i32_load8_u;
|
|
export var no_dce_i64_load = retasmFunc.no_dce_i64_load;
|
|
export var no_dce_i64_load32_s = retasmFunc.no_dce_i64_load32_s;
|
|
export var no_dce_i64_load32_u = retasmFunc.no_dce_i64_load32_u;
|
|
export var no_dce_i64_load16_s = retasmFunc.no_dce_i64_load16_s;
|
|
export var no_dce_i64_load16_u = retasmFunc.no_dce_i64_load16_u;
|
|
export var no_dce_i64_load8_s = retasmFunc.no_dce_i64_load8_s;
|
|
export var no_dce_i64_load8_u = retasmFunc.no_dce_i64_load8_u;
|
|
export var no_dce_f32_load = retasmFunc.no_dce_f32_load;
|
|
export var no_dce_f64_load = retasmFunc.no_dce_f64_load;
|