1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
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
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
|
.include "constants/gba_constants.inc"
.include "asm/macros.inc"
.syntax unified
.text
thumb_func_start sub_800B720
sub_800B720:
push {r4-r7,lr}
mov r7, r10
mov r6, r9
mov r5, r8
push {r5-r7}
sub sp, 0x14
str r1, [sp]
lsls r0, 16
asrs r0, 16
str r0, [sp, 0xC]
bl DisableInterrupts
lsls r0, 24
lsrs r0, 24
str r0, [sp, 0x4]
ldr r0, _0800B780
mov r8, r0
ldr r1, _0800B784
mov r10, r1
ldr r2, _0800B788
mov r9, r2
ldr r5, _0800B78C
mov r12, r5
_0800B74E:
movs r7, 0
str r7, [sp, 0x10]
movs r4, 0
ldr r3, _0800B784
mov r1, r8
movs r2, 0
ldrsh r0, [r1, r2]
ldr r6, _0800B78C
ldr r5, [sp, 0xC]
lsls r5, 16
str r5, [sp, 0x8]
cmp r4, r0
bge _0800B7BA
movs r7, 0
ldrsh r1, [r3, r7]
ldrh r2, [r6]
movs r5, 0
ldrsh r0, [r6, r5]
cmp r1, r0
bne _0800B790
adds r0, r2, 0x1
mov r7, r9
ands r0, r7
strh r0, [r6]
b _0800B74E
.align 2, 0
_0800B780: .4byte gUnknown_203B0AA
_0800B784: .4byte gUnknown_202D608
_0800B788: .4byte 0x00007fff
_0800B78C: .4byte gUnknown_203B0A8
_0800B790:
adds r4, 0x1
adds r3, 0x8
mov r1, r8
movs r2, 0
ldrsh r0, [r1, r2]
cmp r4, r0
bge _0800B7BA
movs r5, 0
ldrsh r1, [r3, r5]
mov r7, r12
ldrh r2, [r7]
movs r5, 0
ldrsh r0, [r7, r5]
cmp r1, r0
bne _0800B790
adds r0, r2, 0x1
mov r7, r9
ands r0, r7
strh r0, [r6]
movs r0, 0x1
str r0, [sp, 0x10]
_0800B7BA:
ldr r1, [sp, 0x10]
cmp r1, 0
bne _0800B74E
movs r4, 0
mov r3, r10
ldr r2, _0800B84C
movs r5, 0
ldrsh r1, [r2, r5]
cmp r4, r1
bge _0800B7EA
movs r7, 0x2
ldrsh r0, [r3, r7]
ldr r2, [sp, 0xC]
cmp r0, r2
bgt _0800B7EA
_0800B7D8:
adds r4, 0x1
adds r3, 0x8
cmp r4, r1
bge _0800B7EA
movs r5, 0x2
ldrsh r0, [r3, r5]
ldr r7, [sp, 0xC]
cmp r0, r7
ble _0800B7D8
_0800B7EA:
ldr r1, _0800B84C
movs r2, 0
ldrsh r0, [r1, r2]
subs r2, r0, 0x1
lsls r0, r2, 3
mov r5, r10
adds r3, r0, r5
lsls r5, r4, 3
cmp r2, r4
blt _0800B80E
_0800B7FE:
ldr r0, [r3]
ldr r1, [r3, 0x4]
str r0, [r3, 0x8]
str r1, [r3, 0xC]
subs r2, 0x1
subs r3, 0x8
cmp r2, r4
bge _0800B7FE
_0800B80E:
ldr r7, _0800B84C
ldrh r0, [r7]
adds r0, 0x1
strh r0, [r7]
mov r0, r10
adds r1, r5, r0
ldrh r0, [r6]
strh r0, [r1]
ldr r2, [sp, 0x8]
lsrs r0, r2, 16
strh r0, [r1, 0x2]
mov r0, r10
adds r0, 0x4
adds r0, r5, r0
ldr r5, [sp]
str r5, [r0]
ldr r7, [sp, 0x4]
cmp r7, 0
beq _0800B838
bl EnableInterrupts
_0800B838:
movs r1, 0
ldrsh r0, [r6, r1]
add sp, 0x14
pop {r3-r5}
mov r8, r3
mov r9, r4
mov r10, r5
pop {r4-r7}
pop {r1}
bx r1
.align 2, 0
_0800B84C: .4byte gUnknown_203B0AA
thumb_func_end sub_800B720
thumb_func_start sub_800B850
sub_800B850:
push {r4-r7,lr}
lsls r0, 16
asrs r6, r0, 16
bl DisableInterrupts
lsls r0, 24
lsrs r5, r0, 24
movs r2, 0
ldr r4, _0800B8A0
ldr r3, _0800B8A4
movs r1, 0
ldrsh r0, [r3, r1]
cmp r2, r0
bge _0800B8B4
adds r1, r3, 0
_0800B86E:
movs r7, 0
ldrsh r0, [r4, r7]
cmp r0, r6
bne _0800B8A8
ldrh r0, [r1]
subs r0, 0x1
strh r0, [r1]
movs r3, 0
ldrsh r0, [r1, r3]
cmp r2, r0
bge _0800B896
ldr r3, _0800B8A4
_0800B886:
ldr r0, [r4, 0x8]
ldr r1, [r4, 0xC]
stm r4!, {r0,r1}
adds r2, 0x1
movs r7, 0
ldrsh r0, [r3, r7]
cmp r2, r0
blt _0800B886
_0800B896:
cmp r5, 0
beq _0800B8BC
bl EnableInterrupts
b _0800B8BC
.align 2, 0
_0800B8A0: .4byte gUnknown_202D608
_0800B8A4: .4byte gUnknown_203B0AA
_0800B8A8:
adds r2, 0x1
adds r4, 0x8
movs r7, 0
ldrsh r0, [r3, r7]
cmp r2, r0
blt _0800B86E
_0800B8B4:
cmp r5, 0
beq _0800B8BC
bl EnableInterrupts
_0800B8BC:
pop {r4-r7}
pop {r0}
bx r0
thumb_func_end sub_800B850
thumb_func_start nullsub_177
nullsub_177:
bx lr
thumb_func_end nullsub_177
thumb_func_start VBlankIntr
VBlankIntr:
push {r4-r7,lr}
mov r7, r10
mov r6, r9
mov r5, r8
push {r5-r7}
ldr r0, _0800B95C
ldr r1, [r0]
adds r1, 0x1
str r1, [r0]
bl SoundVSync
bl BlinkSavingIcon
ldr r0, _0800B960
ldr r0, [r0, 0x4]
cmp r0, 0
beq _0800B8EE
bl _call_via_r0
_0800B8EE:
movs r2, 0
ldr r3, _0800B964
movs r1, 0
ldrsh r0, [r3, r1]
adds r6, r3, 0
ldr r7, _0800B968
ldr r1, _0800B96C
mov r12, r1
ldr r1, _0800B970
mov r8, r1
ldr r1, _0800B974
mov r9, r1
ldr r1, _0800B978
mov r10, r1
cmp r2, r0
bge _0800B920
ldr r5, _0800B97C
ldr r4, _0800B980
_0800B912:
ldm r5!, {r0,r1}
stm r4!, {r0,r1}
adds r2, 0x1
movs r1, 0
ldrsh r0, [r3, r1]
cmp r2, r0
blt _0800B912
_0800B920:
ldrh r0, [r6]
strh r0, [r7]
movs r1, 0x1
negs r1, r1
adds r0, r1, 0
mov r1, r12
strh r0, [r1]
mov r1, r8
strh r0, [r1]
mov r1, r9
strh r0, [r1]
ldr r1, _0800B984
movs r0, 0x28
strh r0, [r1]
mov r1, r10
ldrb r0, [r1]
cmp r0, 0
bne _0800B948
bl UpdateSound
_0800B948:
movs r0, 0x1
bl SetInterruptFlag
pop {r3-r5}
mov r8, r3
mov r9, r4
mov r10, r5
pop {r4-r7}
pop {r0}
bx r0
.align 2, 0
_0800B95C: .4byte gUnknown_203B0A0
_0800B960: .4byte gUnknown_202D5F0
_0800B964: .4byte gUnknown_203B0AA
_0800B968: .4byte gUnknown_203B0AC
_0800B96C: .4byte gUnknown_203B0AE
_0800B970: .4byte gUnknown_203B0B0
_0800B974: .4byte gUnknown_203B0B2
_0800B978: .4byte gUnknown_203B099
_0800B97C: .4byte gUnknown_202D608
_0800B980: .4byte gUnknown_202D648
_0800B984: .4byte 0x04000004
thumb_func_end VBlankIntr
thumb_func_start VCountIntr
VCountIntr:
push {r4-r7,lr}
mov r7, r8
push {r7}
ldr r0, _0800BA44
ldrh r0, [r0]
lsls r0, 16
asrs r6, r0, 16
ldr r0, _0800BA48
movs r2, 0
ldrsh r1, [r0, r2]
adds r7, r0, 0
cmp r1, 0
bge _0800B9B2
ldr r0, _0800BA4C
ldr r0, [r0, 0x8]
cmp r0, 0
beq _0800B9AE
bl _call_via_r0
_0800B9AE:
movs r0, 0
strh r0, [r7]
_0800B9B2:
ldr r0, _0800BA50
movs r3, 0
ldrsh r2, [r7, r3]
movs r3, 0
ldrsh r1, [r0, r3]
mov r8, r0
cmp r2, r1
bge _0800BA34
ldr r1, _0800BA54
adds r0, r2, 0
lsls r0, 3
adds r0, r1
movs r3, 0x2
ldrsh r0, [r0, r3]
cmp r0, r6
bgt _0800BA10
adds r5, r1, 0
adds r4, r7, 0
_0800B9D6:
movs r1, 0
ldrsh r0, [r4, r1]
lsls r0, 3
adds r1, r5, 0x4
adds r0, r1
ldr r0, [r0]
cmp r0, 0
beq _0800B9EA
bl _call_via_r0
_0800B9EA:
ldrh r0, [r4]
adds r0, 0x1
strh r0, [r4]
ldr r1, _0800BA50
lsls r0, 16
asrs r0, 16
movs r2, 0
ldrsh r1, [r1, r2]
cmp r0, r1
bge _0800BA34
movs r3, 0
ldrsh r0, [r4, r3]
lsls r0, 3
adds r0, r5
movs r1, 0x2
ldrsh r0, [r0, r1]
ldr r7, _0800BA48
cmp r0, r6
ble _0800B9D6
_0800BA10:
movs r2, 0
ldrsh r1, [r7, r2]
mov r3, r8
movs r2, 0
ldrsh r0, [r3, r2]
cmp r1, r0
bge _0800BA34
ldr r2, _0800BA58
ldr r1, _0800BA54
movs r3, 0
ldrsh r0, [r7, r3]
lsls r0, 3
adds r0, r1
ldrh r0, [r0, 0x2]
lsls r0, 8
movs r1, 0x28
orrs r0, r1
strh r0, [r2]
_0800BA34:
movs r0, 0x4
bl SetInterruptFlag
pop {r3}
mov r8, r3
pop {r4-r7}
pop {r0}
bx r0
.align 2, 0
_0800BA44: .4byte 0x04000006
_0800BA48: .4byte gUnknown_203B0AE
_0800BA4C: .4byte gUnknown_202D5F0
_0800BA50: .4byte gUnknown_203B0AC
_0800BA54: .4byte gUnknown_202D648
_0800BA58: .4byte 0x04000004
thumb_func_end VCountIntr
.align 2, 0 @ Don't pad with nop.
|