0
|
1 diff --git a/src/fastLong.js b/src/fastLong.js
|
|
2 index 2b70b2f..977c7ec 100644
|
|
3 --- a/src/fastLong.js
|
|
4 +++ b/src/fastLong.js
|
|
5 @@ -12,47 +12,6 @@ function ___muldsi3($a, $b) {
|
|
6 $12 = Math_imul($11, $1) | 0;
|
|
7 return (tempRet0 = (($8 >>> 16) + (Math_imul($11, $6) | 0) | 0) + ((($8 & 65535) + $12 | 0) >>> 16) | 0, 0 | ($8 + $12 << 16 | $3 & 65535)) | 0;
|
|
8 }
|
|
9 -function ___divdi3($a$0, $a$1, $b$0, $b$1) {
|
|
10 - $a$0 = $a$0 | 0;
|
|
11 - $a$1 = $a$1 | 0;
|
|
12 - $b$0 = $b$0 | 0;
|
|
13 - $b$1 = $b$1 | 0;
|
|
14 - var $1$0 = 0, $1$1 = 0, $2$0 = 0, $2$1 = 0, $4$0 = 0, $4$1 = 0, $6$0 = 0, $7$0 = 0, $7$1 = 0, $8$0 = 0, $10$0 = 0;
|
|
15 - $1$0 = $a$1 >> 31 | (($a$1 | 0) < 0 ? -1 : 0) << 1;
|
|
16 - $1$1 = (($a$1 | 0) < 0 ? -1 : 0) >> 31 | (($a$1 | 0) < 0 ? -1 : 0) << 1;
|
|
17 - $2$0 = $b$1 >> 31 | (($b$1 | 0) < 0 ? -1 : 0) << 1;
|
|
18 - $2$1 = (($b$1 | 0) < 0 ? -1 : 0) >> 31 | (($b$1 | 0) < 0 ? -1 : 0) << 1;
|
|
19 - $4$0 = _i64Subtract($1$0 ^ $a$0, $1$1 ^ $a$1, $1$0, $1$1) | 0;
|
|
20 - $4$1 = tempRet0;
|
|
21 - $6$0 = _i64Subtract($2$0 ^ $b$0, $2$1 ^ $b$1, $2$0, $2$1) | 0;
|
|
22 - $7$0 = $2$0 ^ $1$0;
|
|
23 - $7$1 = $2$1 ^ $1$1;
|
|
24 - $8$0 = ___udivmoddi4($4$0, $4$1, $6$0, tempRet0, 0) | 0;
|
|
25 - $10$0 = _i64Subtract($8$0 ^ $7$0, tempRet0 ^ $7$1, $7$0, $7$1) | 0;
|
|
26 - return (tempRet0 = tempRet0, $10$0) | 0;
|
|
27 -}
|
|
28 -function ___remdi3($a$0, $a$1, $b$0, $b$1) {
|
|
29 - $a$0 = $a$0 | 0;
|
|
30 - $a$1 = $a$1 | 0;
|
|
31 - $b$0 = $b$0 | 0;
|
|
32 - $b$1 = $b$1 | 0;
|
|
33 - var $rem = 0, $1$0 = 0, $1$1 = 0, $2$0 = 0, $2$1 = 0, $4$0 = 0, $4$1 = 0, $6$0 = 0, $10$0 = 0, $10$1 = 0, __stackBase__ = 0;
|
|
34 - __stackBase__ = STACKTOP;
|
|
35 - STACKTOP = STACKTOP + 8 | 0;
|
|
36 - $rem = __stackBase__ | 0;
|
|
37 - $1$0 = $a$1 >> 31 | (($a$1 | 0) < 0 ? -1 : 0) << 1;
|
|
38 - $1$1 = (($a$1 | 0) < 0 ? -1 : 0) >> 31 | (($a$1 | 0) < 0 ? -1 : 0) << 1;
|
|
39 - $2$0 = $b$1 >> 31 | (($b$1 | 0) < 0 ? -1 : 0) << 1;
|
|
40 - $2$1 = (($b$1 | 0) < 0 ? -1 : 0) >> 31 | (($b$1 | 0) < 0 ? -1 : 0) << 1;
|
|
41 - $4$0 = _i64Subtract($1$0 ^ $a$0, $1$1 ^ $a$1, $1$0, $1$1) | 0;
|
|
42 - $4$1 = tempRet0;
|
|
43 - $6$0 = _i64Subtract($2$0 ^ $b$0, $2$1 ^ $b$1, $2$0, $2$1) | 0;
|
|
44 - ___udivmoddi4($4$0, $4$1, $6$0, tempRet0, $rem) | 0;
|
|
45 - $10$0 = _i64Subtract(HEAP32[$rem >> 2] ^ $1$0, HEAP32[$rem + 4 >> 2] ^ $1$1, $1$0, $1$1) | 0;
|
|
46 - $10$1 = tempRet0;
|
|
47 - STACKTOP = __stackBase__;
|
|
48 - return (tempRet0 = $10$1, $10$0) | 0;
|
|
49 -}
|
|
50 function ___muldi3($a$0, $a$1, $b$0, $b$1) {
|
|
51 $a$0 = $a$0 | 0;
|
|
52 $a$1 = $a$1 | 0;
|
|
53 @@ -66,234 +25,5 @@ function ___muldi3($a$0, $a$1, $b$0, $b$1) {
|
|
54 $2 = Math_imul($a$1, $y_sroa_0_0_extract_trunc) | 0;
|
|
55 return (tempRet0 = ((Math_imul($b$1, $x_sroa_0_0_extract_trunc) | 0) + $2 | 0) + $1$1 | $1$1 & 0, 0 | $1$0 & -1) | 0;
|
|
56 }
|
|
57 -function ___udivdi3($a$0, $a$1, $b$0, $b$1) {
|
|
58 - $a$0 = $a$0 | 0;
|
|
59 - $a$1 = $a$1 | 0;
|
|
60 - $b$0 = $b$0 | 0;
|
|
61 - $b$1 = $b$1 | 0;
|
|
62 - var $1$0 = 0;
|
|
63 - $1$0 = ___udivmoddi4($a$0, $a$1, $b$0, $b$1, 0) | 0;
|
|
64 - return (tempRet0 = tempRet0, $1$0) | 0;
|
|
65 -}
|
|
66 -function ___uremdi3($a$0, $a$1, $b$0, $b$1) {
|
|
67 - $a$0 = $a$0 | 0;
|
|
68 - $a$1 = $a$1 | 0;
|
|
69 - $b$0 = $b$0 | 0;
|
|
70 - $b$1 = $b$1 | 0;
|
|
71 - var $rem = 0, __stackBase__ = 0;
|
|
72 - __stackBase__ = STACKTOP;
|
|
73 - STACKTOP = STACKTOP + 8 | 0;
|
|
74 - $rem = __stackBase__ | 0;
|
|
75 - ___udivmoddi4($a$0, $a$1, $b$0, $b$1, $rem) | 0;
|
|
76 - STACKTOP = __stackBase__;
|
|
77 - return (tempRet0 = HEAP32[$rem + 4 >> 2] | 0, HEAP32[$rem >> 2] | 0) | 0;
|
|
78 -}
|
|
79 -function ___udivmoddi4($a$0, $a$1, $b$0, $b$1, $rem) {
|
|
80 - $a$0 = $a$0 | 0;
|
|
81 - $a$1 = $a$1 | 0;
|
|
82 - $b$0 = $b$0 | 0;
|
|
83 - $b$1 = $b$1 | 0;
|
|
84 - $rem = $rem | 0;
|
|
85 - var $n_sroa_0_0_extract_trunc = 0, $n_sroa_1_4_extract_shift$0 = 0, $n_sroa_1_4_extract_trunc = 0, $d_sroa_0_0_extract_trunc = 0, $d_sroa_1_4_extract_shift$0 = 0, $d_sroa_1_4_extract_trunc = 0, $4 = 0, $17 = 0, $37 = 0, $49 = 0, $51 = 0, $57 = 0, $58 = 0, $66 = 0, $78 = 0, $86 = 0, $88 = 0, $89 = 0, $91 = 0, $92 = 0, $95 = 0, $105 = 0, $117 = 0, $119 = 0, $125 = 0, $126 = 0, $130 = 0, $q_sroa_1_1_ph = 0, $q_sroa_0_1_ph = 0, $r_sroa_1_1_ph = 0, $r_sroa_0_1_ph = 0, $sr_1_ph = 0, $d_sroa_0_0_insert_insert99$0 = 0, $d_sroa_0_0_insert_insert99$1 = 0, $137$0 = 0, $137$1 = 0, $carry_0203 = 0, $sr_1202 = 0, $r_sroa_0_1201 = 0, $r_sroa_1_1200 = 0, $q_sroa_0_1199 = 0, $q_sroa_1_1198 = 0, $147 = 0, $149 = 0, $r_sroa_0_0_insert_insert42$0 = 0, $r_sroa_0_0_insert_insert42$1 = 0, $150$1 = 0, $151$0 = 0, $152 = 0, $154$0 = 0, $r_sroa_0_0_extract_trunc = 0, $r_sroa_1_4_extract_trunc = 0, $155 = 0, $carry_0_lcssa$0 = 0, $carry_0_lcssa$1 = 0, $r_sroa_0_1_lcssa = 0, $r_sroa_1_1_lcssa = 0, $q_sroa_0_1_lcssa = 0, $q_sroa_1_1_lcssa = 0, $q_sroa_0_0_insert_ext75$0 = 0, $q_sroa_0_0_insert_ext75$1 = 0, $q_sroa_0_0_insert_insert77$1 = 0, $_0$0 = 0, $_0$1 = 0;
|
|
86 - $n_sroa_0_0_extract_trunc = $a$0;
|
|
87 - $n_sroa_1_4_extract_shift$0 = $a$1;
|
|
88 - $n_sroa_1_4_extract_trunc = $n_sroa_1_4_extract_shift$0;
|
|
89 - $d_sroa_0_0_extract_trunc = $b$0;
|
|
90 - $d_sroa_1_4_extract_shift$0 = $b$1;
|
|
91 - $d_sroa_1_4_extract_trunc = $d_sroa_1_4_extract_shift$0;
|
|
92 - if (($n_sroa_1_4_extract_trunc | 0) == 0) {
|
|
93 - $4 = ($rem | 0) != 0;
|
|
94 - if (($d_sroa_1_4_extract_trunc | 0) == 0) {
|
|
95 - if ($4) {
|
|
96 - HEAP32[$rem >> 2] = ($n_sroa_0_0_extract_trunc >>> 0) % ($d_sroa_0_0_extract_trunc >>> 0);
|
|
97 - HEAP32[$rem + 4 >> 2] = 0;
|
|
98 - }
|
|
99 - $_0$1 = 0;
|
|
100 - $_0$0 = ($n_sroa_0_0_extract_trunc >>> 0) / ($d_sroa_0_0_extract_trunc >>> 0) >>> 0;
|
|
101 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
102 - } else {
|
|
103 - if (!$4) {
|
|
104 - $_0$1 = 0;
|
|
105 - $_0$0 = 0;
|
|
106 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
107 - }
|
|
108 - HEAP32[$rem >> 2] = $a$0 & -1;
|
|
109 - HEAP32[$rem + 4 >> 2] = $a$1 & 0;
|
|
110 - $_0$1 = 0;
|
|
111 - $_0$0 = 0;
|
|
112 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
113 - }
|
|
114 - }
|
|
115 - $17 = ($d_sroa_1_4_extract_trunc | 0) == 0;
|
|
116 - do {
|
|
117 - if (($d_sroa_0_0_extract_trunc | 0) == 0) {
|
|
118 - if ($17) {
|
|
119 - if (($rem | 0) != 0) {
|
|
120 - HEAP32[$rem >> 2] = ($n_sroa_1_4_extract_trunc >>> 0) % ($d_sroa_0_0_extract_trunc >>> 0);
|
|
121 - HEAP32[$rem + 4 >> 2] = 0;
|
|
122 - }
|
|
123 - $_0$1 = 0;
|
|
124 - $_0$0 = ($n_sroa_1_4_extract_trunc >>> 0) / ($d_sroa_0_0_extract_trunc >>> 0) >>> 0;
|
|
125 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
126 - }
|
|
127 - if (($n_sroa_0_0_extract_trunc | 0) == 0) {
|
|
128 - if (($rem | 0) != 0) {
|
|
129 - HEAP32[$rem >> 2] = 0;
|
|
130 - HEAP32[$rem + 4 >> 2] = ($n_sroa_1_4_extract_trunc >>> 0) % ($d_sroa_1_4_extract_trunc >>> 0);
|
|
131 - }
|
|
132 - $_0$1 = 0;
|
|
133 - $_0$0 = ($n_sroa_1_4_extract_trunc >>> 0) / ($d_sroa_1_4_extract_trunc >>> 0) >>> 0;
|
|
134 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
135 - }
|
|
136 - $37 = $d_sroa_1_4_extract_trunc - 1 | 0;
|
|
137 - if (($37 & $d_sroa_1_4_extract_trunc | 0) == 0) {
|
|
138 - if (($rem | 0) != 0) {
|
|
139 - HEAP32[$rem >> 2] = 0 | $a$0 & -1;
|
|
140 - HEAP32[$rem + 4 >> 2] = $37 & $n_sroa_1_4_extract_trunc | $a$1 & 0;
|
|
141 - }
|
|
142 - $_0$1 = 0;
|
|
143 - $_0$0 = $n_sroa_1_4_extract_trunc >>> ((_llvm_cttz_i32($d_sroa_1_4_extract_trunc | 0) | 0) >>> 0);
|
|
144 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
145 - }
|
|
146 - $49 = _llvm_ctlz_i32($d_sroa_1_4_extract_trunc | 0) | 0;
|
|
147 - $51 = $49 - (_llvm_ctlz_i32($n_sroa_1_4_extract_trunc | 0) | 0) | 0;
|
|
148 - if ($51 >>> 0 <= 30) {
|
|
149 - $57 = $51 + 1 | 0;
|
|
150 - $58 = 31 - $51 | 0;
|
|
151 - $sr_1_ph = $57;
|
|
152 - $r_sroa_0_1_ph = $n_sroa_1_4_extract_trunc << $58 | $n_sroa_0_0_extract_trunc >>> ($57 >>> 0);
|
|
153 - $r_sroa_1_1_ph = $n_sroa_1_4_extract_trunc >>> ($57 >>> 0);
|
|
154 - $q_sroa_0_1_ph = 0;
|
|
155 - $q_sroa_1_1_ph = $n_sroa_0_0_extract_trunc << $58;
|
|
156 - break;
|
|
157 - }
|
|
158 - if (($rem | 0) == 0) {
|
|
159 - $_0$1 = 0;
|
|
160 - $_0$0 = 0;
|
|
161 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
162 - }
|
|
163 - HEAP32[$rem >> 2] = 0 | $a$0 & -1;
|
|
164 - HEAP32[$rem + 4 >> 2] = $n_sroa_1_4_extract_shift$0 | $a$1 & 0;
|
|
165 - $_0$1 = 0;
|
|
166 - $_0$0 = 0;
|
|
167 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
168 - } else {
|
|
169 - if (!$17) {
|
|
170 - $117 = _llvm_ctlz_i32($d_sroa_1_4_extract_trunc | 0) | 0;
|
|
171 - $119 = $117 - (_llvm_ctlz_i32($n_sroa_1_4_extract_trunc | 0) | 0) | 0;
|
|
172 - if ($119 >>> 0 <= 31) {
|
|
173 - $125 = $119 + 1 | 0;
|
|
174 - $126 = 31 - $119 | 0;
|
|
175 - $130 = $119 - 31 >> 31;
|
|
176 - $sr_1_ph = $125;
|
|
177 - $r_sroa_0_1_ph = $n_sroa_0_0_extract_trunc >>> ($125 >>> 0) & $130 | $n_sroa_1_4_extract_trunc << $126;
|
|
178 - $r_sroa_1_1_ph = $n_sroa_1_4_extract_trunc >>> ($125 >>> 0) & $130;
|
|
179 - $q_sroa_0_1_ph = 0;
|
|
180 - $q_sroa_1_1_ph = $n_sroa_0_0_extract_trunc << $126;
|
|
181 - break;
|
|
182 - }
|
|
183 - if (($rem | 0) == 0) {
|
|
184 - $_0$1 = 0;
|
|
185 - $_0$0 = 0;
|
|
186 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
187 - }
|
|
188 - HEAP32[$rem >> 2] = 0 | $a$0 & -1;
|
|
189 - HEAP32[$rem + 4 >> 2] = $n_sroa_1_4_extract_shift$0 | $a$1 & 0;
|
|
190 - $_0$1 = 0;
|
|
191 - $_0$0 = 0;
|
|
192 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
193 - }
|
|
194 - $66 = $d_sroa_0_0_extract_trunc - 1 | 0;
|
|
195 - if (($66 & $d_sroa_0_0_extract_trunc | 0) != 0) {
|
|
196 - $86 = (_llvm_ctlz_i32($d_sroa_0_0_extract_trunc | 0) | 0) + 33 | 0;
|
|
197 - $88 = $86 - (_llvm_ctlz_i32($n_sroa_1_4_extract_trunc | 0) | 0) | 0;
|
|
198 - $89 = 64 - $88 | 0;
|
|
199 - $91 = 32 - $88 | 0;
|
|
200 - $92 = $91 >> 31;
|
|
201 - $95 = $88 - 32 | 0;
|
|
202 - $105 = $95 >> 31;
|
|
203 - $sr_1_ph = $88;
|
|
204 - $r_sroa_0_1_ph = $91 - 1 >> 31 & $n_sroa_1_4_extract_trunc >>> ($95 >>> 0) | ($n_sroa_1_4_extract_trunc << $91 | $n_sroa_0_0_extract_trunc >>> ($88 >>> 0)) & $105;
|
|
205 - $r_sroa_1_1_ph = $105 & $n_sroa_1_4_extract_trunc >>> ($88 >>> 0);
|
|
206 - $q_sroa_0_1_ph = $n_sroa_0_0_extract_trunc << $89 & $92;
|
|
207 - $q_sroa_1_1_ph = ($n_sroa_1_4_extract_trunc << $89 | $n_sroa_0_0_extract_trunc >>> ($95 >>> 0)) & $92 | $n_sroa_0_0_extract_trunc << $91 & $88 - 33 >> 31;
|
|
208 - break;
|
|
209 - }
|
|
210 - if (($rem | 0) != 0) {
|
|
211 - HEAP32[$rem >> 2] = $66 & $n_sroa_0_0_extract_trunc;
|
|
212 - HEAP32[$rem + 4 >> 2] = 0;
|
|
213 - }
|
|
214 - if (($d_sroa_0_0_extract_trunc | 0) == 1) {
|
|
215 - $_0$1 = $n_sroa_1_4_extract_shift$0 | $a$1 & 0;
|
|
216 - $_0$0 = 0 | $a$0 & -1;
|
|
217 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
218 - } else {
|
|
219 - $78 = _llvm_cttz_i32($d_sroa_0_0_extract_trunc | 0) | 0;
|
|
220 - $_0$1 = 0 | $n_sroa_1_4_extract_trunc >>> ($78 >>> 0);
|
|
221 - $_0$0 = $n_sroa_1_4_extract_trunc << 32 - $78 | $n_sroa_0_0_extract_trunc >>> ($78 >>> 0) | 0;
|
|
222 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
223 - }
|
|
224 - }
|
|
225 - } while (0);
|
|
226 - if (($sr_1_ph | 0) == 0) {
|
|
227 - $q_sroa_1_1_lcssa = $q_sroa_1_1_ph;
|
|
228 - $q_sroa_0_1_lcssa = $q_sroa_0_1_ph;
|
|
229 - $r_sroa_1_1_lcssa = $r_sroa_1_1_ph;
|
|
230 - $r_sroa_0_1_lcssa = $r_sroa_0_1_ph;
|
|
231 - $carry_0_lcssa$1 = 0;
|
|
232 - $carry_0_lcssa$0 = 0;
|
|
233 - } else {
|
|
234 - $d_sroa_0_0_insert_insert99$0 = 0 | $b$0 & -1;
|
|
235 - $d_sroa_0_0_insert_insert99$1 = $d_sroa_1_4_extract_shift$0 | $b$1 & 0;
|
|
236 - $137$0 = _i64Add($d_sroa_0_0_insert_insert99$0, $d_sroa_0_0_insert_insert99$1, -1, -1) | 0;
|
|
237 - $137$1 = tempRet0;
|
|
238 - $q_sroa_1_1198 = $q_sroa_1_1_ph;
|
|
239 - $q_sroa_0_1199 = $q_sroa_0_1_ph;
|
|
240 - $r_sroa_1_1200 = $r_sroa_1_1_ph;
|
|
241 - $r_sroa_0_1201 = $r_sroa_0_1_ph;
|
|
242 - $sr_1202 = $sr_1_ph;
|
|
243 - $carry_0203 = 0;
|
|
244 - while (1) {
|
|
245 - $147 = $q_sroa_0_1199 >>> 31 | $q_sroa_1_1198 << 1;
|
|
246 - $149 = $carry_0203 | $q_sroa_0_1199 << 1;
|
|
247 - $r_sroa_0_0_insert_insert42$0 = 0 | ($r_sroa_0_1201 << 1 | $q_sroa_1_1198 >>> 31);
|
|
248 - $r_sroa_0_0_insert_insert42$1 = $r_sroa_0_1201 >>> 31 | $r_sroa_1_1200 << 1 | 0;
|
|
249 - _i64Subtract($137$0, $137$1, $r_sroa_0_0_insert_insert42$0, $r_sroa_0_0_insert_insert42$1) | 0;
|
|
250 - $150$1 = tempRet0;
|
|
251 - $151$0 = $150$1 >> 31 | (($150$1 | 0) < 0 ? -1 : 0) << 1;
|
|
252 - $152 = $151$0 & 1;
|
|
253 - $154$0 = _i64Subtract($r_sroa_0_0_insert_insert42$0, $r_sroa_0_0_insert_insert42$1, $151$0 & $d_sroa_0_0_insert_insert99$0, ((($150$1 | 0) < 0 ? -1 : 0) >> 31 | (($150$1 | 0) < 0 ? -1 : 0) << 1) & $d_sroa_0_0_insert_insert99$1) | 0;
|
|
254 - $r_sroa_0_0_extract_trunc = $154$0;
|
|
255 - $r_sroa_1_4_extract_trunc = tempRet0;
|
|
256 - $155 = $sr_1202 - 1 | 0;
|
|
257 - if (($155 | 0) == 0) {
|
|
258 - break;
|
|
259 - } else {
|
|
260 - $q_sroa_1_1198 = $147;
|
|
261 - $q_sroa_0_1199 = $149;
|
|
262 - $r_sroa_1_1200 = $r_sroa_1_4_extract_trunc;
|
|
263 - $r_sroa_0_1201 = $r_sroa_0_0_extract_trunc;
|
|
264 - $sr_1202 = $155;
|
|
265 - $carry_0203 = $152;
|
|
266 - }
|
|
267 - }
|
|
268 - $q_sroa_1_1_lcssa = $147;
|
|
269 - $q_sroa_0_1_lcssa = $149;
|
|
270 - $r_sroa_1_1_lcssa = $r_sroa_1_4_extract_trunc;
|
|
271 - $r_sroa_0_1_lcssa = $r_sroa_0_0_extract_trunc;
|
|
272 - $carry_0_lcssa$1 = 0;
|
|
273 - $carry_0_lcssa$0 = $152;
|
|
274 - }
|
|
275 - $q_sroa_0_0_insert_ext75$0 = $q_sroa_0_1_lcssa;
|
|
276 - $q_sroa_0_0_insert_ext75$1 = 0;
|
|
277 - $q_sroa_0_0_insert_insert77$1 = $q_sroa_1_1_lcssa | $q_sroa_0_0_insert_ext75$1;
|
|
278 - if (($rem | 0) != 0) {
|
|
279 - HEAP32[$rem >> 2] = 0 | $r_sroa_0_1_lcssa;
|
|
280 - HEAP32[$rem + 4 >> 2] = $r_sroa_1_1_lcssa | 0;
|
|
281 - }
|
|
282 - $_0$1 = (0 | $q_sroa_0_0_insert_ext75$0) >>> 31 | $q_sroa_0_0_insert_insert77$1 << 1 | ($q_sroa_0_0_insert_ext75$1 << 1 | $q_sroa_0_0_insert_ext75$0 >>> 31) & 0 | $carry_0_lcssa$1;
|
|
283 - $_0$0 = ($q_sroa_0_0_insert_ext75$0 << 1 | 0 >>> 31) & -2 | $carry_0_lcssa$0;
|
|
284 - return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
285 -}
|
|
286 // =======================================================================
|
|
287
|
|
288 diff --git a/src/jsifier.js b/src/jsifier.js
|
|
289 index a717b79..51bab6f 100644
|
|
290 --- a/src/jsifier.js
|
|
291 +++ b/src/jsifier.js
|
|
292 @@ -1883,8 +1883,14 @@ function JSify(data, functionsOnly) {
|
|
293 }
|
|
294 // these may be duplicated in side modules and the main module without issue
|
|
295 print(read('fastLong.js'));
|
|
296 + if (!USE_BPG_STRIP)
|
|
297 + print(read('fastLongDiv.js'));
|
|
298 print('// EMSCRIPTEN_END_FUNCS\n');
|
|
299 - print(read('long.js'));
|
|
300 + if (PRECISE_I64_MATH == 2) {
|
|
301 + print('var i64Math = null;');
|
|
302 + } else {
|
|
303 + print(read('long.js'));
|
|
304 + }
|
|
305 } else {
|
|
306 print('// EMSCRIPTEN_END_FUNCS\n');
|
|
307 print('// Warning: printing of i64 values may be slightly rounded! No deep i64 math used, so precise i64 code not included');
|
|
308 diff --git a/src/postamble.js b/src/postamble.js
|
|
309 index bac17ab..06800ee 100644
|
|
310 --- a/src/postamble.js
|
|
311 +++ b/src/postamble.js
|
|
312 @@ -52,6 +52,7 @@ dependenciesFulfilled = function runCaller() {
|
|
313 if (!Module['calledRun']) dependenciesFulfilled = runCaller; // try this again later, after new deps are fulfilled
|
|
314 }
|
|
315
|
|
316 +#if !USE_BPG_STRIP
|
|
317 Module['callMain'] = Module.callMain = function callMain(args) {
|
|
318 assert(runDependencies == 0, 'cannot call main when async dependencies remain! (listen on __ATMAIN__)');
|
|
319 assert(__ATPRERUN__.length == 0, 'cannot call main when preRun functions remain to be called');
|
|
320 @@ -108,6 +109,7 @@ Module['callMain'] = Module.callMain = function callMain(args) {
|
|
321 calledMain = true;
|
|
322 }
|
|
323 }
|
|
324 +#endif
|
|
325
|
|
326 {{GLOBAL_VARS}}
|
|
327
|
|
328 @@ -142,9 +144,11 @@ function run(args) {
|
|
329 Module.printErr('pre-main prep time: ' + (Date.now() - preloadStartTime) + ' ms');
|
|
330 }
|
|
331
|
|
332 +#if !USE_BPG_STRIP
|
|
333 if (Module['_main'] && shouldRunNow) {
|
|
334 Module['callMain'](args);
|
|
335 }
|
|
336 +#endif
|
|
337
|
|
338 postRun();
|
|
339 }
|
|
340 diff --git a/src/preamble.js b/src/preamble.js
|
|
341 index a1bc48e..9a2e36b 100644
|
|
342 --- a/src/preamble.js
|
|
343 +++ b/src/preamble.js
|
|
344 @@ -633,6 +633,8 @@ function allocate(slab, types, allocator, ptr) {
|
|
345 }
|
|
346 Module['allocate'] = allocate;
|
|
347
|
|
348 +#if !USE_BPG_STRIP
|
|
349 +
|
|
350 function Pointer_stringify(ptr, /* optional */ length) {
|
|
351 if (length === 0) return '';
|
|
352 // TODO: use TextDecoder
|
|
353 @@ -924,6 +926,11 @@ function demangle(func) {
|
|
354 function demangleAll(text) {
|
|
355 return text.replace(/__Z[\w\d_]+/g, function(x) { var y = demangle(x); return x === y ? x : (x + ' [' + y + ']') });
|
|
356 }
|
|
357 +#else
|
|
358 +function demangleAll(text) {
|
|
359 + return text;
|
|
360 +}
|
|
361 +#endif
|
|
362
|
|
363 function jsStackTrace() {
|
|
364 var err = new Error();
|
|
365 diff --git a/src/settings.js b/src/settings.js
|
|
366 index eb34d2d..49a0a11 100644
|
|
367 --- a/src/settings.js
|
|
368 +++ b/src/settings.js
|
|
369 @@ -594,6 +594,8 @@ var USE_SDL = 1; // Specify the SDL version that is being linked against.
|
|
370 // 2 is a port of the SDL C code on emscripten-ports
|
|
371 var USE_SDL_IMAGE = 1; // Specify the SDL_image version that is being linked against. Must match USE_SDL
|
|
372
|
|
373 +// strip unused code by BPG
|
|
374 +var USE_BPG_STRIP = 1;
|
|
375
|
|
376 // Compiler debugging options
|
|
377 var DEBUG_TAGS_SHOWING = [];
|
|
378 diff --git a/src/fastLongDiv.js b/src/fastLongDiv.js
|
|
379 new file mode 100644
|
|
380 index 0000000..d1e5b49
|
|
381 --- /dev/null
|
|
382 +++ b/src/fastLongDiv.js
|
|
383 @@ -0,0 +1,273 @@
|
|
384 +// ======== compiled code from system/lib/compiler-rt , see readme therein
|
|
385 +function ___divdi3($a$0, $a$1, $b$0, $b$1) {
|
|
386 + $a$0 = $a$0 | 0;
|
|
387 + $a$1 = $a$1 | 0;
|
|
388 + $b$0 = $b$0 | 0;
|
|
389 + $b$1 = $b$1 | 0;
|
|
390 + var $1$0 = 0, $1$1 = 0, $2$0 = 0, $2$1 = 0, $4$0 = 0, $4$1 = 0, $6$0 = 0, $7$0 = 0, $7$1 = 0, $8$0 = 0, $10$0 = 0;
|
|
391 + $1$0 = $a$1 >> 31 | (($a$1 | 0) < 0 ? -1 : 0) << 1;
|
|
392 + $1$1 = (($a$1 | 0) < 0 ? -1 : 0) >> 31 | (($a$1 | 0) < 0 ? -1 : 0) << 1;
|
|
393 + $2$0 = $b$1 >> 31 | (($b$1 | 0) < 0 ? -1 : 0) << 1;
|
|
394 + $2$1 = (($b$1 | 0) < 0 ? -1 : 0) >> 31 | (($b$1 | 0) < 0 ? -1 : 0) << 1;
|
|
395 + $4$0 = _i64Subtract($1$0 ^ $a$0, $1$1 ^ $a$1, $1$0, $1$1) | 0;
|
|
396 + $4$1 = tempRet0;
|
|
397 + $6$0 = _i64Subtract($2$0 ^ $b$0, $2$1 ^ $b$1, $2$0, $2$1) | 0;
|
|
398 + $7$0 = $2$0 ^ $1$0;
|
|
399 + $7$1 = $2$1 ^ $1$1;
|
|
400 + $8$0 = ___udivmoddi4($4$0, $4$1, $6$0, tempRet0, 0) | 0;
|
|
401 + $10$0 = _i64Subtract($8$0 ^ $7$0, tempRet0 ^ $7$1, $7$0, $7$1) | 0;
|
|
402 + return (tempRet0 = tempRet0, $10$0) | 0;
|
|
403 +}
|
|
404 +function ___remdi3($a$0, $a$1, $b$0, $b$1) {
|
|
405 + $a$0 = $a$0 | 0;
|
|
406 + $a$1 = $a$1 | 0;
|
|
407 + $b$0 = $b$0 | 0;
|
|
408 + $b$1 = $b$1 | 0;
|
|
409 + var $rem = 0, $1$0 = 0, $1$1 = 0, $2$0 = 0, $2$1 = 0, $4$0 = 0, $4$1 = 0, $6$0 = 0, $10$0 = 0, $10$1 = 0, __stackBase__ = 0;
|
|
410 + __stackBase__ = STACKTOP;
|
|
411 + STACKTOP = STACKTOP + 8 | 0;
|
|
412 + $rem = __stackBase__ | 0;
|
|
413 + $1$0 = $a$1 >> 31 | (($a$1 | 0) < 0 ? -1 : 0) << 1;
|
|
414 + $1$1 = (($a$1 | 0) < 0 ? -1 : 0) >> 31 | (($a$1 | 0) < 0 ? -1 : 0) << 1;
|
|
415 + $2$0 = $b$1 >> 31 | (($b$1 | 0) < 0 ? -1 : 0) << 1;
|
|
416 + $2$1 = (($b$1 | 0) < 0 ? -1 : 0) >> 31 | (($b$1 | 0) < 0 ? -1 : 0) << 1;
|
|
417 + $4$0 = _i64Subtract($1$0 ^ $a$0, $1$1 ^ $a$1, $1$0, $1$1) | 0;
|
|
418 + $4$1 = tempRet0;
|
|
419 + $6$0 = _i64Subtract($2$0 ^ $b$0, $2$1 ^ $b$1, $2$0, $2$1) | 0;
|
|
420 + ___udivmoddi4($4$0, $4$1, $6$0, tempRet0, $rem) | 0;
|
|
421 + $10$0 = _i64Subtract(HEAP32[$rem >> 2] ^ $1$0, HEAP32[$rem + 4 >> 2] ^ $1$1, $1$0, $1$1) | 0;
|
|
422 + $10$1 = tempRet0;
|
|
423 + STACKTOP = __stackBase__;
|
|
424 + return (tempRet0 = $10$1, $10$0) | 0;
|
|
425 +}
|
|
426 +function ___udivdi3($a$0, $a$1, $b$0, $b$1) {
|
|
427 + $a$0 = $a$0 | 0;
|
|
428 + $a$1 = $a$1 | 0;
|
|
429 + $b$0 = $b$0 | 0;
|
|
430 + $b$1 = $b$1 | 0;
|
|
431 + var $1$0 = 0;
|
|
432 + $1$0 = ___udivmoddi4($a$0, $a$1, $b$0, $b$1, 0) | 0;
|
|
433 + return (tempRet0 = tempRet0, $1$0) | 0;
|
|
434 +}
|
|
435 +function ___uremdi3($a$0, $a$1, $b$0, $b$1) {
|
|
436 + $a$0 = $a$0 | 0;
|
|
437 + $a$1 = $a$1 | 0;
|
|
438 + $b$0 = $b$0 | 0;
|
|
439 + $b$1 = $b$1 | 0;
|
|
440 + var $rem = 0, __stackBase__ = 0;
|
|
441 + __stackBase__ = STACKTOP;
|
|
442 + STACKTOP = STACKTOP + 8 | 0;
|
|
443 + $rem = __stackBase__ | 0;
|
|
444 + ___udivmoddi4($a$0, $a$1, $b$0, $b$1, $rem) | 0;
|
|
445 + STACKTOP = __stackBase__;
|
|
446 + return (tempRet0 = HEAP32[$rem + 4 >> 2] | 0, HEAP32[$rem >> 2] | 0) | 0;
|
|
447 +}
|
|
448 +function ___udivmoddi4($a$0, $a$1, $b$0, $b$1, $rem) {
|
|
449 + $a$0 = $a$0 | 0;
|
|
450 + $a$1 = $a$1 | 0;
|
|
451 + $b$0 = $b$0 | 0;
|
|
452 + $b$1 = $b$1 | 0;
|
|
453 + $rem = $rem | 0;
|
|
454 + var $n_sroa_0_0_extract_trunc = 0, $n_sroa_1_4_extract_shift$0 = 0, $n_sroa_1_4_extract_trunc = 0, $d_sroa_0_0_extract_trunc = 0, $d_sroa_1_4_extract_shift$0 = 0, $d_sroa_1_4_extract_trunc = 0, $4 = 0, $17 = 0, $37 = 0, $49 = 0, $51 = 0, $57 = 0, $58 = 0, $66 = 0, $78 = 0, $86 = 0, $88 = 0, $89 = 0, $91 = 0, $92 = 0, $95 = 0, $105 = 0, $117 = 0, $119 = 0, $125 = 0, $126 = 0, $130 = 0, $q_sroa_1_1_ph = 0, $q_sroa_0_1_ph = 0, $r_sroa_1_1_ph = 0, $r_sroa_0_1_ph = 0, $sr_1_ph = 0, $d_sroa_0_0_insert_insert99$0 = 0, $d_sroa_0_0_insert_insert99$1 = 0, $137$0 = 0, $137$1 = 0, $carry_0203 = 0, $sr_1202 = 0, $r_sroa_0_1201 = 0, $r_sroa_1_1200 = 0, $q_sroa_0_1199 = 0, $q_sroa_1_1198 = 0, $147 = 0, $149 = 0, $r_sroa_0_0_insert_insert42$0 = 0, $r_sroa_0_0_insert_insert42$1 = 0, $150$1 = 0, $151$0 = 0, $152 = 0, $154$0 = 0, $r_sroa_0_0_extract_trunc = 0, $r_sroa_1_4_extract_trunc = 0, $155 = 0, $carry_0_lcssa$0 = 0, $carry_0_lcssa$1 = 0, $r_sroa_0_1_lcssa = 0, $r_sroa_1_1_lcssa = 0, $q_sroa_0_1_lcssa = 0, $q_sroa_1_1_lcssa = 0, $q_sroa_0_0_insert_ext75$0 = 0, $q_sroa_0_0_insert_ext75$1 = 0, $q_sroa_0_0_insert_insert77$1 = 0, $_0$0 = 0, $_0$1 = 0;
|
|
455 + $n_sroa_0_0_extract_trunc = $a$0;
|
|
456 + $n_sroa_1_4_extract_shift$0 = $a$1;
|
|
457 + $n_sroa_1_4_extract_trunc = $n_sroa_1_4_extract_shift$0;
|
|
458 + $d_sroa_0_0_extract_trunc = $b$0;
|
|
459 + $d_sroa_1_4_extract_shift$0 = $b$1;
|
|
460 + $d_sroa_1_4_extract_trunc = $d_sroa_1_4_extract_shift$0;
|
|
461 + if (($n_sroa_1_4_extract_trunc | 0) == 0) {
|
|
462 + $4 = ($rem | 0) != 0;
|
|
463 + if (($d_sroa_1_4_extract_trunc | 0) == 0) {
|
|
464 + if ($4) {
|
|
465 + HEAP32[$rem >> 2] = ($n_sroa_0_0_extract_trunc >>> 0) % ($d_sroa_0_0_extract_trunc >>> 0);
|
|
466 + HEAP32[$rem + 4 >> 2] = 0;
|
|
467 + }
|
|
468 + $_0$1 = 0;
|
|
469 + $_0$0 = ($n_sroa_0_0_extract_trunc >>> 0) / ($d_sroa_0_0_extract_trunc >>> 0) >>> 0;
|
|
470 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
471 + } else {
|
|
472 + if (!$4) {
|
|
473 + $_0$1 = 0;
|
|
474 + $_0$0 = 0;
|
|
475 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
476 + }
|
|
477 + HEAP32[$rem >> 2] = $a$0 & -1;
|
|
478 + HEAP32[$rem + 4 >> 2] = $a$1 & 0;
|
|
479 + $_0$1 = 0;
|
|
480 + $_0$0 = 0;
|
|
481 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
482 + }
|
|
483 + }
|
|
484 + $17 = ($d_sroa_1_4_extract_trunc | 0) == 0;
|
|
485 + do {
|
|
486 + if (($d_sroa_0_0_extract_trunc | 0) == 0) {
|
|
487 + if ($17) {
|
|
488 + if (($rem | 0) != 0) {
|
|
489 + HEAP32[$rem >> 2] = ($n_sroa_1_4_extract_trunc >>> 0) % ($d_sroa_0_0_extract_trunc >>> 0);
|
|
490 + HEAP32[$rem + 4 >> 2] = 0;
|
|
491 + }
|
|
492 + $_0$1 = 0;
|
|
493 + $_0$0 = ($n_sroa_1_4_extract_trunc >>> 0) / ($d_sroa_0_0_extract_trunc >>> 0) >>> 0;
|
|
494 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
495 + }
|
|
496 + if (($n_sroa_0_0_extract_trunc | 0) == 0) {
|
|
497 + if (($rem | 0) != 0) {
|
|
498 + HEAP32[$rem >> 2] = 0;
|
|
499 + HEAP32[$rem + 4 >> 2] = ($n_sroa_1_4_extract_trunc >>> 0) % ($d_sroa_1_4_extract_trunc >>> 0);
|
|
500 + }
|
|
501 + $_0$1 = 0;
|
|
502 + $_0$0 = ($n_sroa_1_4_extract_trunc >>> 0) / ($d_sroa_1_4_extract_trunc >>> 0) >>> 0;
|
|
503 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
504 + }
|
|
505 + $37 = $d_sroa_1_4_extract_trunc - 1 | 0;
|
|
506 + if (($37 & $d_sroa_1_4_extract_trunc | 0) == 0) {
|
|
507 + if (($rem | 0) != 0) {
|
|
508 + HEAP32[$rem >> 2] = 0 | $a$0 & -1;
|
|
509 + HEAP32[$rem + 4 >> 2] = $37 & $n_sroa_1_4_extract_trunc | $a$1 & 0;
|
|
510 + }
|
|
511 + $_0$1 = 0;
|
|
512 + $_0$0 = $n_sroa_1_4_extract_trunc >>> ((_llvm_cttz_i32($d_sroa_1_4_extract_trunc | 0) | 0) >>> 0);
|
|
513 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
514 + }
|
|
515 + $49 = _llvm_ctlz_i32($d_sroa_1_4_extract_trunc | 0) | 0;
|
|
516 + $51 = $49 - (_llvm_ctlz_i32($n_sroa_1_4_extract_trunc | 0) | 0) | 0;
|
|
517 + if ($51 >>> 0 <= 30) {
|
|
518 + $57 = $51 + 1 | 0;
|
|
519 + $58 = 31 - $51 | 0;
|
|
520 + $sr_1_ph = $57;
|
|
521 + $r_sroa_0_1_ph = $n_sroa_1_4_extract_trunc << $58 | $n_sroa_0_0_extract_trunc >>> ($57 >>> 0);
|
|
522 + $r_sroa_1_1_ph = $n_sroa_1_4_extract_trunc >>> ($57 >>> 0);
|
|
523 + $q_sroa_0_1_ph = 0;
|
|
524 + $q_sroa_1_1_ph = $n_sroa_0_0_extract_trunc << $58;
|
|
525 + break;
|
|
526 + }
|
|
527 + if (($rem | 0) == 0) {
|
|
528 + $_0$1 = 0;
|
|
529 + $_0$0 = 0;
|
|
530 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
531 + }
|
|
532 + HEAP32[$rem >> 2] = 0 | $a$0 & -1;
|
|
533 + HEAP32[$rem + 4 >> 2] = $n_sroa_1_4_extract_shift$0 | $a$1 & 0;
|
|
534 + $_0$1 = 0;
|
|
535 + $_0$0 = 0;
|
|
536 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
537 + } else {
|
|
538 + if (!$17) {
|
|
539 + $117 = _llvm_ctlz_i32($d_sroa_1_4_extract_trunc | 0) | 0;
|
|
540 + $119 = $117 - (_llvm_ctlz_i32($n_sroa_1_4_extract_trunc | 0) | 0) | 0;
|
|
541 + if ($119 >>> 0 <= 31) {
|
|
542 + $125 = $119 + 1 | 0;
|
|
543 + $126 = 31 - $119 | 0;
|
|
544 + $130 = $119 - 31 >> 31;
|
|
545 + $sr_1_ph = $125;
|
|
546 + $r_sroa_0_1_ph = $n_sroa_0_0_extract_trunc >>> ($125 >>> 0) & $130 | $n_sroa_1_4_extract_trunc << $126;
|
|
547 + $r_sroa_1_1_ph = $n_sroa_1_4_extract_trunc >>> ($125 >>> 0) & $130;
|
|
548 + $q_sroa_0_1_ph = 0;
|
|
549 + $q_sroa_1_1_ph = $n_sroa_0_0_extract_trunc << $126;
|
|
550 + break;
|
|
551 + }
|
|
552 + if (($rem | 0) == 0) {
|
|
553 + $_0$1 = 0;
|
|
554 + $_0$0 = 0;
|
|
555 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
556 + }
|
|
557 + HEAP32[$rem >> 2] = 0 | $a$0 & -1;
|
|
558 + HEAP32[$rem + 4 >> 2] = $n_sroa_1_4_extract_shift$0 | $a$1 & 0;
|
|
559 + $_0$1 = 0;
|
|
560 + $_0$0 = 0;
|
|
561 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
562 + }
|
|
563 + $66 = $d_sroa_0_0_extract_trunc - 1 | 0;
|
|
564 + if (($66 & $d_sroa_0_0_extract_trunc | 0) != 0) {
|
|
565 + $86 = (_llvm_ctlz_i32($d_sroa_0_0_extract_trunc | 0) | 0) + 33 | 0;
|
|
566 + $88 = $86 - (_llvm_ctlz_i32($n_sroa_1_4_extract_trunc | 0) | 0) | 0;
|
|
567 + $89 = 64 - $88 | 0;
|
|
568 + $91 = 32 - $88 | 0;
|
|
569 + $92 = $91 >> 31;
|
|
570 + $95 = $88 - 32 | 0;
|
|
571 + $105 = $95 >> 31;
|
|
572 + $sr_1_ph = $88;
|
|
573 + $r_sroa_0_1_ph = $91 - 1 >> 31 & $n_sroa_1_4_extract_trunc >>> ($95 >>> 0) | ($n_sroa_1_4_extract_trunc << $91 | $n_sroa_0_0_extract_trunc >>> ($88 >>> 0)) & $105;
|
|
574 + $r_sroa_1_1_ph = $105 & $n_sroa_1_4_extract_trunc >>> ($88 >>> 0);
|
|
575 + $q_sroa_0_1_ph = $n_sroa_0_0_extract_trunc << $89 & $92;
|
|
576 + $q_sroa_1_1_ph = ($n_sroa_1_4_extract_trunc << $89 | $n_sroa_0_0_extract_trunc >>> ($95 >>> 0)) & $92 | $n_sroa_0_0_extract_trunc << $91 & $88 - 33 >> 31;
|
|
577 + break;
|
|
578 + }
|
|
579 + if (($rem | 0) != 0) {
|
|
580 + HEAP32[$rem >> 2] = $66 & $n_sroa_0_0_extract_trunc;
|
|
581 + HEAP32[$rem + 4 >> 2] = 0;
|
|
582 + }
|
|
583 + if (($d_sroa_0_0_extract_trunc | 0) == 1) {
|
|
584 + $_0$1 = $n_sroa_1_4_extract_shift$0 | $a$1 & 0;
|
|
585 + $_0$0 = 0 | $a$0 & -1;
|
|
586 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
587 + } else {
|
|
588 + $78 = _llvm_cttz_i32($d_sroa_0_0_extract_trunc | 0) | 0;
|
|
589 + $_0$1 = 0 | $n_sroa_1_4_extract_trunc >>> ($78 >>> 0);
|
|
590 + $_0$0 = $n_sroa_1_4_extract_trunc << 32 - $78 | $n_sroa_0_0_extract_trunc >>> ($78 >>> 0) | 0;
|
|
591 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
592 + }
|
|
593 + }
|
|
594 + } while (0);
|
|
595 + if (($sr_1_ph | 0) == 0) {
|
|
596 + $q_sroa_1_1_lcssa = $q_sroa_1_1_ph;
|
|
597 + $q_sroa_0_1_lcssa = $q_sroa_0_1_ph;
|
|
598 + $r_sroa_1_1_lcssa = $r_sroa_1_1_ph;
|
|
599 + $r_sroa_0_1_lcssa = $r_sroa_0_1_ph;
|
|
600 + $carry_0_lcssa$1 = 0;
|
|
601 + $carry_0_lcssa$0 = 0;
|
|
602 + } else {
|
|
603 + $d_sroa_0_0_insert_insert99$0 = 0 | $b$0 & -1;
|
|
604 + $d_sroa_0_0_insert_insert99$1 = $d_sroa_1_4_extract_shift$0 | $b$1 & 0;
|
|
605 + $137$0 = _i64Add($d_sroa_0_0_insert_insert99$0, $d_sroa_0_0_insert_insert99$1, -1, -1) | 0;
|
|
606 + $137$1 = tempRet0;
|
|
607 + $q_sroa_1_1198 = $q_sroa_1_1_ph;
|
|
608 + $q_sroa_0_1199 = $q_sroa_0_1_ph;
|
|
609 + $r_sroa_1_1200 = $r_sroa_1_1_ph;
|
|
610 + $r_sroa_0_1201 = $r_sroa_0_1_ph;
|
|
611 + $sr_1202 = $sr_1_ph;
|
|
612 + $carry_0203 = 0;
|
|
613 + while (1) {
|
|
614 + $147 = $q_sroa_0_1199 >>> 31 | $q_sroa_1_1198 << 1;
|
|
615 + $149 = $carry_0203 | $q_sroa_0_1199 << 1;
|
|
616 + $r_sroa_0_0_insert_insert42$0 = 0 | ($r_sroa_0_1201 << 1 | $q_sroa_1_1198 >>> 31);
|
|
617 + $r_sroa_0_0_insert_insert42$1 = $r_sroa_0_1201 >>> 31 | $r_sroa_1_1200 << 1 | 0;
|
|
618 + _i64Subtract($137$0, $137$1, $r_sroa_0_0_insert_insert42$0, $r_sroa_0_0_insert_insert42$1) | 0;
|
|
619 + $150$1 = tempRet0;
|
|
620 + $151$0 = $150$1 >> 31 | (($150$1 | 0) < 0 ? -1 : 0) << 1;
|
|
621 + $152 = $151$0 & 1;
|
|
622 + $154$0 = _i64Subtract($r_sroa_0_0_insert_insert42$0, $r_sroa_0_0_insert_insert42$1, $151$0 & $d_sroa_0_0_insert_insert99$0, ((($150$1 | 0) < 0 ? -1 : 0) >> 31 | (($150$1 | 0) < 0 ? -1 : 0) << 1) & $d_sroa_0_0_insert_insert99$1) | 0;
|
|
623 + $r_sroa_0_0_extract_trunc = $154$0;
|
|
624 + $r_sroa_1_4_extract_trunc = tempRet0;
|
|
625 + $155 = $sr_1202 - 1 | 0;
|
|
626 + if (($155 | 0) == 0) {
|
|
627 + break;
|
|
628 + } else {
|
|
629 + $q_sroa_1_1198 = $147;
|
|
630 + $q_sroa_0_1199 = $149;
|
|
631 + $r_sroa_1_1200 = $r_sroa_1_4_extract_trunc;
|
|
632 + $r_sroa_0_1201 = $r_sroa_0_0_extract_trunc;
|
|
633 + $sr_1202 = $155;
|
|
634 + $carry_0203 = $152;
|
|
635 + }
|
|
636 + }
|
|
637 + $q_sroa_1_1_lcssa = $147;
|
|
638 + $q_sroa_0_1_lcssa = $149;
|
|
639 + $r_sroa_1_1_lcssa = $r_sroa_1_4_extract_trunc;
|
|
640 + $r_sroa_0_1_lcssa = $r_sroa_0_0_extract_trunc;
|
|
641 + $carry_0_lcssa$1 = 0;
|
|
642 + $carry_0_lcssa$0 = $152;
|
|
643 + }
|
|
644 + $q_sroa_0_0_insert_ext75$0 = $q_sroa_0_1_lcssa;
|
|
645 + $q_sroa_0_0_insert_ext75$1 = 0;
|
|
646 + $q_sroa_0_0_insert_insert77$1 = $q_sroa_1_1_lcssa | $q_sroa_0_0_insert_ext75$1;
|
|
647 + if (($rem | 0) != 0) {
|
|
648 + HEAP32[$rem >> 2] = 0 | $r_sroa_0_1_lcssa;
|
|
649 + HEAP32[$rem + 4 >> 2] = $r_sroa_1_1_lcssa | 0;
|
|
650 + }
|
|
651 + $_0$1 = (0 | $q_sroa_0_0_insert_ext75$0) >>> 31 | $q_sroa_0_0_insert_insert77$1 << 1 | ($q_sroa_0_0_insert_ext75$1 << 1 | $q_sroa_0_0_insert_ext75$0 >>> 31) & 0 | $carry_0_lcssa$1;
|
|
652 + $_0$0 = ($q_sroa_0_0_insert_ext75$0 << 1 | 0 >>> 31) & -2 | $carry_0_lcssa$0;
|
|
653 + return (tempRet0 = $_0$1, $_0$0) | 0;
|
|
654 +}
|
|
655 +// =======================================================================
|
|
656 +
|