https://github.com/akkartik/mu/blob/master/100array-equal.subx
1
2
3 == code
4
5 array-equal?:
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28 55/push-ebp
29 89/<- %ebp 4/r32/esp
30
31 51/push-ecx
32 52/push-edx
33 53/push-ebx
34 56/push-esi
35 57/push-edi
36
37 8b/-> *(ebp+8) 6/r32/esi
38
39 8b/-> *(ebp+0xc) 7/r32/edi
40
41 8b/-> *esi 2/r32/edx
42 $array-equal?:sizes:
43
44 39/compare *edi 2/r32/edx
45 75/jump-if-!= $array-equal?:false/disp8
46
47 81 0/subop/add %esi 4/imm32
48
49 81 0/subop/add %edi 4/imm32
50
51 31/xor-with %ecx 1/r32/ecx
52
53
54 $array-equal?:loop:
55
56 39/compare %ecx 2/r32/edx
57 7d/jump-if->= $array-equal?:true/disp8
58
59 8b/-> *esi 0/r32/eax
60
61 8b/-> *edi 3/r32/ebx
62
63 39/compare %eax 3/r32/ebx
64 75/jump-if-!= $array-equal?:false/disp8
65
66 81 0/subop/add %ecx 4/imm32
67
68 81 0/subop/add %esi 4/imm32
69
70 81 0/subop/add %edi 4/imm32
71 eb/jump $array-equal?:loop/disp8
72 $array-equal?:true:
73 b8/copy-to-eax 1/imm32
74 eb/jump $array-equal?:end/disp8
75 $array-equal?:false:
76 b8/copy-to-eax 0/imm32
77 $array-equal?:end:
78
79 5f/pop-to-edi
80 5e/pop-to-esi
81 5b/pop-to-ebx
82 5a/pop-to-edx
83 59/pop-to-ecx
84
85 89/<- %esp 5/r32/ebp
86 5d/pop-to-ebp
87 c3/return
88
89 test-compare-empty-with-empty-array:
90
91 55/push-ebp
92 89/<- %ebp 4/r32/esp
93
94 68/push 0/imm32/size
95 89/<- %ecx 4/r32/esp
96
97 68/push 0/imm32/size
98 89/<- %edx 4/r32/esp
99
100 (array-equal? %ecx %edx)
101 (check-ints-equal %eax 1 "F - test-compare-empty-with-empty-array")
102
103 89/<- %esp 5/r32/ebp
104 5d/pop-to-ebp
105 c3/return
106
107 test-compare-empty-with-non-empty-array:
108
109 55/push-ebp
110 89/<- %ebp 4/r32/esp
111
112 68/push 1/imm32
113 68/push 4/imm32/size
114 89/<- %ecx 4/r32/esp
115
116 68/push 0/imm32/size
117 89/<- %edx 4/r32/esp
118
119 (array-equal? %ecx %edx)
120 (check-ints-equal %eax 0 "F - test-compare-empty-with-non-empty-array")
121
122 89/<- %esp 5/r32/ebp
123 5d/pop-to-ebp
124 c3/return
125
126 test-compare-equal-arrays:
127
128 55/push-ebp
129 89/<- %ebp 4/r32/esp
130
131 68/push 3/imm32
132 68/push 2/imm32
133 68/push 1/imm32
134 68/push 0xc/imm32/size
135 89/<- %ecx 4/r32/esp
136
137 68/push 3/imm32
138 68/push 2/imm32
139 68/push 1/imm32
140 68/push 0xc/imm32/size
141 89/<- %edx 4/r32/esp
142
143 (array-equal? %ecx %edx)
144 (check-ints-equal %eax 1 "F - test-compare-equal-arrays")
145
146 89/<- %esp 5/r32/ebp
147 5d/pop-to-ebp
148 c3/return
149
150 test-compare-inequal-arrays-equal-sizes:
151
152 55/push-ebp
153 89/<- %ebp 4/r32/esp
154
155 68/push 3/imm32
156 68/push 4/imm32
157 68/push 1/imm32
158 68/push 0xc/imm32/size
159 89/<- %ecx 4/r32/esp
160
161 68/push 3/imm32
162 68/push 2/imm32
163 68/push 1/imm32
164 68/push 0xc/imm32/size
165 89/<- %edx 4/r32/esp
166
167 (array-equal? %ecx %edx)
168 (check-ints-equal %eax 0 "F - test-compare-inequal-arrays-equal-sizes")
169
170 89/<- %esp 5/r32/ebp
171 5d/pop-to-ebp
172 c3/return
173
174 parse-array-of-ints:
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199 55/push-ebp
200 89/<- %ebp 4/r32/esp
201
202 50/push-eax
203 51/push-ecx
204 52/push-edx
205 53/push-ebx
206 56/push-esi
207 57/push-edi
208
209 8b/-> *(ebp+0xc) 6/r32/esi
210
211 8d/copy-address *(esi+4) 1/r32/ecx
212
213
214 8b/-> *esi 2/r32/edx
215
216 01/add-to %edx 1/r32/ecx
217
218 31/xor-with %ebx 3/r32/ebx
219 $parse-array-of-ints:loop1:
220
221 39/compare %ecx 2/r32/edx
222 73/jump-if-addr>= $parse-array-of-ints:break1/disp8
223
224 (skip-chars-matching-in-slice %ecx %edx 0x20)
225 89/<- %ecx 0/r32/eax
226
227 39/compare %ecx 2/r32/edx
228 73/jump-if-addr>= $parse-array-of-ints:break1/disp8
229
230 (skip-chars-not-matching-in-slice %ecx %edx 0x20)
231 89/<- %ecx 0/r32/eax
232
233 81 0/subop/add %ebx 4/imm32
234 eb/jump $parse-array-of-ints:loop1/disp8
235 $parse-array-of-ints:break1:
236 (allocate-array *(ebp+8) %ebx *(ebp+0x10))
237 $parse-array-of-ints:pass2:
238
239 68/push 0/imm32/end
240 8d/copy-address *(esi+4) 7/r32/edi
241 57/push-edi
242 89/<- %edi 4/r32/esp
243
244 8b/-> *(ebp+0x10) 0/r32/eax
245 (lookup *eax *(eax+4))
246 8d/copy-address *(eax+4) 1/r32/ecx
247 $parse-array-of-ints:loop2:
248
249 39/compare *edi 2/r32/edx
250 73/jump-if-addr>= $parse-array-of-ints:end/disp8
251
252 (skip-chars-matching-in-slice *edi %edx 0x20)
253 89/<- *edi 0/r32/eax
254
255 39/compare *edi 2/r32/edx
256 73/jump-if-addr>= $parse-array-of-ints:end/disp8
257
258 (skip-chars-not-matching-in-slice *edi %edx 0x20)
259 89/<- *(edi+4) 0/r32/eax
260
261 (parse-hex-int-from-slice %edi)
262 89/<- *ecx 0/r32/eax
263
264 81 0/subop/add %ecx 4/imm32
265
266 8b/-> *(edi+4) 0/r32/eax
267 89/<- *edi 0/r32/eax
268 eb/jump $parse-array-of-ints:loop2/disp8
269 $parse-array-of-ints:end:
270
271 81 0/subop/add %esp 8/imm32
272
273 5f/pop-to-edi
274 5e/pop-to-esi
275 5b/pop-to-ebx
276 5a/pop-to-edx
277 59/pop-to-ecx
278 58/pop-to-eax
279
280 89/<- %esp 5/r32/ebp
281 5d/pop-to-ebp
282 c3/return
283
284 test-parse-array-of-ints:
285
286 55/push-ebp
287 89/<- %ebp 4/r32/esp
288
289 68/push 0/imm32
290 68/push 0/imm32
291 89/<- %esi 4/r32/esp
292
293 68/push 3/imm32
294 68/push 2/imm32
295 68/push 1/imm32
296 68/push 0xc/imm32/size
297 89/<- %ecx 4/r32/esp
298
299 (parse-array-of-ints Heap "1 2 3" %esi)
300 (lookup *esi *(esi+4))
301 (array-equal? %ecx %eax)
302 (check-ints-equal %eax 1 "F - test-parse-array-of-ints")
303
304 89/<- %esp 5/r32/ebp
305 5d/pop-to-ebp
306 c3/return
307
308 test-parse-array-of-ints-empty:
309
310
311 55/push-ebp
312 89/<- %ebp 4/r32/esp
313
314 68/push 0/imm32
315 68/push 0/imm32
316 89/<- %esi 4/r32/esp
317
318 (parse-array-of-ints Heap "" %esi)
319 (lookup *esi *(esi+4))
320 (check-ints-equal *eax 0 "F - test-parse-array-of-ints-empty")
321
322 89/<- %esp 5/r32/ebp
323 5d/pop-to-ebp
324 c3/return
325
326 test-parse-array-of-ints-just-whitespace:
327
328
329 55/push-ebp
330 89/<- %ebp 4/r32/esp
331
332 68/push 0/imm32
333 68/push 0/imm32
334 89/<- %esi 4/r32/esp
335
336 (parse-array-of-ints Heap Space %esi)
337 (lookup *esi *(esi+4))
338 (check-ints-equal *eax 0 "F - test-parse-array-of-ints-just-whitespace")
339
340 89/<- %esp 5/r32/ebp
341 5d/pop-to-ebp
342 c3/return
343
344 test-parse-array-of-ints-extra-whitespace:
345
346 55/push-ebp
347 89/<- %ebp 4/r32/esp
348
349 68/push 0/imm32
350 68/push 0/imm32
351 89/<- %esi 4/r32/esp
352
353 68/push 3/imm32
354 68/push 2/imm32
355 68/push 1/imm32
356 68/push 0xc/imm32/size
357 89/<- %ecx 4/r32/esp
358
359 (parse-array-of-ints Heap " 1 2 3 " %esi)
360 (lookup *esi *(esi+4))
361 (array-equal? %ecx %eax)
362 (check-ints-equal %eax 1 "F - test-parse-array-of-ints-extra-whitespace")
363
364 89/<- %esp 5/r32/ebp
365 5d/pop-to-ebp
366 c3/return
367
368
369
370 check-array-equal:
371
372 55/push-ebp
373 89/<- %ebp 4/r32/esp
374
375 50/push-eax
376 56/push-esi
377
378 68/push 0/imm32
379 68/push 0/imm32
380 89/<- %esi 4/r32/esp
381
382 (parse-array-of-ints Heap *(ebp+0xc) %esi)
383 (lookup *esi *(esi+4))
384
385 (array-equal? *(ebp+8) %eax)
386 (check-ints-equal %eax 1 *(ebp+0x10))
387 $check-array-equal:end:
388
389 5e/pop-to-esi
390 58/pop-to-eax
391
392 89/<- %esp 5/r32/ebp
393 5d/pop-to-ebp
394 c3/return
395
396 test-check-array-equal:
397
398 55/push-ebp
399 89/<- %ebp 4/r32/esp
400
401 68/push 3/imm32
402 68/push 2/imm32
403 68/push 1/imm32
404 68/push 0xc/imm32/size
405 89/<- %ecx 4/r32/esp
406
407 (check-array-equal %ecx "1 2 3" "F - test-check-array-equal")
408
409 89/<- %esp 5/r32/ebp
410 5d/pop-to-ebp
411 c3/return
412
413