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
|
#include "asm/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
.align 2, 0 @ Don't pad with nop.
|