summaryrefslogtreecommitdiff
path: root/arm9/asm/RUNTIME_f_div.s
blob: 4f7c6d157439911fb0fcabe87dbbb31d926fb18b (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
	.include "asm/macros.inc"
	.include "global.inc"

	.text

	arm_func_start _frdiv
_frdiv: ; 0x020EB078
	eor r0, r0, r1
	eor r1, r0, r1
	eor r0, r0, r1

	arm_func_start _fdiv
_fdiv: ; 0x020EB084
	stmdb sp!, {lr}
	mov r12, #0xff
	ands r3, r12, r0, lsr #0x17
	cmpne r3, #0xff
	beq _020EB258
	ands r12, r12, r1, lsr #0x17
	cmpne r12, #0xff
	beq _020EB294
	orr r1, r1, #0x800000
	orr r0, r0, #0x800000
	bic r2, r0, #0xff000000
	bic lr, r1, #0xff000000
_020EB0B4:
	cmp r2, lr
	movcc r2, r2, lsl #0x1
	subcc r3, r3, #0x1
	teq r0, r1
	sub r0, pc, #0x94 ; _020EB138 - #0x100
	ldrb r1, [r0, lr, lsr #0xf]
	rsb lr, lr, #0x0
	mov r0, lr, asr #0x1
	mul r0, r1, r0
	add r0, r0, #0x80000000
	mov r0, r0, lsr #0x6
	mul r0, r1, r0
	mov r0, r0, lsr #0xe
	mul r1, lr, r0
	sub r12, r3, r12
	mov r1, r1, lsr #0xc
	mul r1, r0, r1
	mov r0, r0, lsl #0xe
	add r0, r0, r1, lsr #0xf
	umull r1, r0, r2, r0
	mov r3, r0
	orrmi r0, r0, #0x80000000
	adds r12, r12, #0x7e
	bmi _020EB35C
	cmp r12, #0xfe
	bge _020EB410
	add r0, r0, r12, lsl #0x17
	mov r12, r1, lsr #0x1c
	cmp r12, #0x7
	beq _020EB238
	add r0, r0, r1, lsr #0x1f
	ldmia sp!, {lr}
	bx lr
_020EB138: ; not code
	.byte 0xFF, 0xFF, 0xFE, 0xFD, 0xFC, 0xFB, 0xFA, 0xF9
	.byte 0xF8, 0xF7, 0xF6, 0xF5, 0xF4, 0xF3, 0xF2, 0xF1, 0xF0, 0xF0, 0xEF, 0xEE, 0xED, 0xEC, 0xEB, 0xEA
	.byte 0xEA, 0xE9, 0xE8, 0xE7, 0xE6, 0xE6, 0xE5, 0xE4, 0xE3, 0xE2, 0xE2, 0xE1, 0xE0, 0xDF, 0xDF, 0xDE
	.byte 0xDD, 0xDC, 0xDC, 0xDB, 0xDA, 0xD9, 0xD9, 0xD8, 0xD7, 0xD7, 0xD6, 0xD5, 0xD4, 0xD4, 0xD3, 0xD2
	.byte 0xD2, 0xD1, 0xD0, 0xD0, 0xCF, 0xCE, 0xCE, 0xCD, 0xCC, 0xCC, 0xCB, 0xCB, 0xCA, 0xC9, 0xC9, 0xC8
	.byte 0xC8, 0xC7, 0xC6, 0xC6, 0xC5, 0xC5, 0xC4, 0xC3, 0xC3, 0xC2, 0xC2, 0xC1, 0xC0, 0xC0, 0xBF, 0xBF
	.byte 0xBE, 0xBE, 0xBD, 0xBD, 0xBC, 0xBC, 0xBB, 0xBA, 0xBA, 0xB9, 0xB9, 0xB8, 0xB8, 0xB7, 0xB7, 0xB6
	.byte 0xB6, 0xB5, 0xB5, 0xB4, 0xB4, 0xB3, 0xB3, 0xB2, 0xB2, 0xB1, 0xB1, 0xB0, 0xB0, 0xAF, 0xAF, 0xAF
	.byte 0xAE, 0xAE, 0xAD, 0xAD, 0xAC, 0xAC, 0xAB, 0xAB, 0xAA, 0xAA, 0xAA, 0xA9, 0xA9, 0xA8, 0xA8, 0xA7
	.byte 0xA7, 0xA7, 0xA6, 0xA6, 0xA5, 0xA5, 0xA4, 0xA4, 0xA4, 0xA3, 0xA3, 0xA2, 0xA2, 0xA2, 0xA1, 0xA1
	.byte 0xA0, 0xA0, 0xA0, 0x9F, 0x9F, 0x9E, 0x9E, 0x9E, 0x9D, 0x9D, 0x9D, 0x9C, 0x9C, 0x9B, 0x9B, 0x9B
	.byte 0x9A, 0x9A, 0x9A, 0x99, 0x99, 0x99, 0x98, 0x98, 0x98, 0x97, 0x97, 0x96, 0x96, 0x96, 0x95, 0x95
	.byte 0x95, 0x94, 0x94, 0x94, 0x93, 0x93, 0x93, 0x92, 0x92, 0x92, 0x91, 0x91, 0x91, 0x91, 0x90, 0x90
	.byte 0x90, 0x8F, 0x8F, 0x8F, 0x8E, 0x8E, 0x8E, 0x8D, 0x8D, 0x8D, 0x8C, 0x8C, 0x8C, 0x8C, 0x8B, 0x8B
	.byte 0x8B, 0x8A, 0x8A, 0x8A, 0x8A, 0x89, 0x89, 0x89, 0x88, 0x88, 0x88, 0x88, 0x87, 0x87, 0x87, 0x86
	.byte 0x86, 0x86, 0x86, 0x85, 0x85, 0x85, 0x85, 0x84, 0x84, 0x84, 0x83, 0x83, 0x83, 0x83, 0x82, 0x82
	.byte 0x82, 0x82, 0x81, 0x81, 0x81, 0x81, 0x80, 0x80
_020EB238:
	mov r1, r3, lsl #0x1
	add r1, r1, #0x1
	rsb lr, lr, #0x0
	mul r1, lr, r1
	cmp r1, r2, lsl #0x18
	addmi r0, r0, #0x1
	ldmia sp!, {lr}
	bx lr
_020EB258:
	eor lr, r0, r1
	and lr, lr, #0x80000000
	cmp r3, #0x0
	beq _020EB2B0
	movs r0, r0, lsl #0x9
	bne _020EB3F8
	mov r12, r1, lsr #0x17
	mov r1, r1, lsl #0x9
	ands r12, r12, #0xff
	beq _020EB3E8
	cmp r12, #0xff
	blt _020EB3E8
	cmp r1, #0x0
	beq _020EB404
	b _020EB3E0
_020EB294:
	eor lr, r0, r1
	and lr, lr, #0x80000000
	cmp r12, #0x0
	beq _020EB314
_020EB2A4:
	movs r1, r1, lsl #0x9
	bne _020EB3E0
	b _020EB430
_020EB2B0:
	movs r2, r0, lsl #0x9
	beq _020EB2E4
	clz r3, r2
	movs r2, r2, lsl r3
	rsb r3, r3, #0x0
	mov r2, r2, lsr #0x8
	ands r12, r12, r1, lsr #0x17
	beq _020EB33C
	cmp r12, #0xff
	beq _020EB2A4
	orr r1, r1, #0x800000
	bic lr, r1, #0xff000000
	b _020EB0B4
_020EB2E4:
	mov r12, r1, lsr #0x17
	mov r1, r1, lsl #0x9
	ands r12, r12, #0xff
	beq _020EB308
	cmp r12, #0xff
	blt _020EB430
	cmp r1, #0x0
	beq _020EB430
	b _020EB3E0
_020EB308:
	cmp r1, #0x0
	beq _020EB404
	b _020EB430
_020EB314:
	movs r12, r1, lsl #0x9
	beq _020EB3E8
	mov lr, r12
	clz r12, lr
	movs lr, lr, lsl r12
	rsb r12, r12, #0x0
	mov lr, lr, lsr #0x8
	orr r0, r0, #0x800000
	bic r2, r0, #0xff000000
	b _020EB0B4
_020EB33C:
	movs r12, r1, lsl #0x9
	beq _020EB3E8
	mov lr, r12
	clz r12, lr
	movs lr, lr, lsl r12
	rsb r12, r12, #0x0
	mov lr, lr, lsr #0x8
	b _020EB0B4
_020EB35C:
	and r0, r0, #0x80000000
	cmn r12, #0x18
	beq _020EB3D0
	bmi _020EB428
	add r1, r12, #0x17
	mov r2, r2, lsl r1
	rsb r12, r12, #0x0
	mov r3, r3, lsr r12
	orr r0, r0, r3
	rsb lr, lr, #0x0
	mul r1, lr, r3
	cmp r1, r2
	ldmeqia sp!, {lr}
	bxeq lr
	add r1, r1, lr
	cmp r1, r2
	beq _020EB3C4
	addmi r0, r0, #0x1
	subpl r1, r1, lr
	add r1, lr, r1, lsl #0x1
	cmp r1, r2, lsl #0x1
	and r3, r0, #0x1
	addmi r0, r0, #0x1
	addeq r0, r0, r3
	ldmia sp!, {lr}
	bx lr
_020EB3C4:
	add r0, r0, #0x1
	ldmia sp!, {lr}
	bx lr
_020EB3D0:
	cmn r2, lr
	addne r0, r0, #0x1
	ldmia sp!, {lr}
	bx lr
_020EB3E0:
	mov r0, r1
	b _020EB3F8
_020EB3E8:
	mov r0, #0xff000000
	orr r0, lr, r0, lsr #0x1
	ldmia sp!, {lr}
	bx lr
_020EB3F8:
	mvn r0, #0x80000000
	ldmia sp!, {lr}
	bx lr
_020EB404:
	mvn r0, #0x80000000
	ldmia sp!, {lr}
	bx lr
_020EB410:
	tst r0, #0x80000000
	mov r0, #0xff000000
	movne r0, r0, asr #0x1
	moveq r0, r0, lsr #0x1
	ldmia sp!, {lr}
	bx lr
_020EB428:
	ldmia sp!, {lr}
	bx lr
_020EB430:
	mov r0, lr
	ldmia sp!, {lr}
	bx lr