summaryrefslogtreecommitdiff
path: root/asm/code_800B5F0.s
blob: bcad95abae4bd0ba471e8376bc5a75f9e93b338c (plain)
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.