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
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
|
.include "asm/macros.inc"
.include "global.inc"
.section .rodata
.global pivotUtil_
pivotUtil_: ; 0x020FFA14
.byte 0x04, 0x05, 0x07, 0x08
.byte 0x03, 0x05, 0x06, 0x08
.byte 0x03, 0x04, 0x06, 0x07
.byte 0x01, 0x02, 0x07, 0x08
.byte 0x00, 0x02, 0x06, 0x08
.byte 0x00, 0x01, 0x06, 0x07
.byte 0x01, 0x02, 0x04, 0x05
.byte 0x00, 0x02, 0x03, 0x05
.byte 0x00, 0x01, 0x03, 0x04
.section .text
arm_func_start getRotDataByIdx_
getRotDataByIdx_: ; 0x020BC500
stmdb sp!, {r4,lr}
ands r4, r3, #0x8000
beq _020BC5E0
mov r2, #0x0
str r2, [r0, #0x20]
ldr r4, [r0, #0x20]
ldr r2, _020BC684 ; =0x00007FFF
str r4, [r0, #0x1c]
ldr r4, [r0, #0x1c]
and r3, r3, r2
str r4, [r0, #0x18]
ldr r4, [r0, #0x18]
mov r2, #0x3
str r4, [r0, #0x14]
ldr r4, [r0, #0x14]
mul r2, r3, r2
str r4, [r0, #0x10]
ldr r4, [r0, #0x10]
mov r3, r2, lsl #0x1
str r4, [r0, #0xc]
ldr r4, [r0, #0xc]
add r2, r1, r2, lsl #0x1
str r4, [r0, #0x8]
ldr r4, [r0, #0x8]
str r4, [r0, #0x4]
ldr r4, [r0, #0x4]
str r4, [r0, #0x0]
ldrsh r4, [r1, r3]
ldrsh r12, [r2, #0x2]
ldrsh r3, [r2, #0x4]
and r1, r4, #0xf
ands r4, r4, #0x10
movne lr, #0x1000
rsbne lr, lr, #0x0
moveq lr, #0x1000
str lr, [r0, r1, lsl #0x2]
ldr r4, _020BC688 ; =pivotUtil_
ldr lr, _020BC68C ; =pivotUtil_ + 1
ldrb r4, [r4, r1, lsl #0x2]
str r12, [r0, r4, lsl #0x2]
ldrb lr, [lr, r1, lsl #0x2]
str r3, [r0, lr, lsl #0x2]
ldrsh lr, [r2, #0x0]
ands lr, lr, #0x20
ldr lr, _020BC690 ; =pivotUtil_ + 2
rsbne r3, r3, #0x0
ldrb lr, [lr, r1, lsl #0x2]
str r3, [r0, lr, lsl #0x2]
ldrsh r2, [r2, #0x0]
ands r2, r2, #0x40
ldr r2, _020BC694 ; =pivotUtil_ + 3
rsbne r12, r12, #0x0
ldrb r1, [r2, r1, lsl #0x2]
str r12, [r0, r1, lsl #0x2]
mov r0, #0x0
ldmia sp!, {r4,pc}
_020BC5E0:
ldr r1, _020BC684 ; =0x00007FFF
mov r12, #0x5
and r1, r3, r1
mul r3, r1, r12
add r1, r2, r3, lsl #0x1
ldrsh lr, [r1, #0x8]
mov r12, r3, lsl #0x1
mov r3, lr, asr #0x3
str r3, [r0, #0x10]
ldrsh r12, [r2, r12]
and r2, lr, #0x7
mov r2, r2, lsl #0x10
mov r3, r12, asr #0x3
str r3, [r0, #0x0]
ldrsh r3, [r1, #0x2]
and r12, r12, #0x7
orr lr, r12, r2, asr #0xd
mov r2, r3, asr #0x3
str r2, [r0, #0x4]
ldrsh r12, [r1, #0x4]
mov r2, lr, lsl #0x10
and lr, r3, #0x7
mov r3, r12, asr #0x3
str r3, [r0, #0x8]
ldrsh r3, [r1, #0x6]
orr r1, lr, r2, asr #0xd
mov r1, r1, lsl #0x10
and r2, r12, #0x7
orr r1, r2, r1, asr #0xd
mov r1, r1, lsl #0x10
and r2, r3, #0x7
orr r1, r2, r1, asr #0xd
mov r1, r1, lsl #0x10
mov r1, r1, asr #0x10
mov r2, r3, asr #0x3
mov r1, r1, lsl #0x13
str r2, [r0, #0xc]
mov r1, r1, asr #0x13
str r1, [r0, #0x14]
mov r0, #0x1
ldmia sp!, {r4,pc}
.balign 4
_020BC684: .word 0x00007FFF
_020BC688: .word pivotUtil_
_020BC68C: .word pivotUtil_ + 1
_020BC690: .word pivotUtil_ + 2
_020BC694: .word pivotUtil_ + 3
arm_func_end getRotDataByIdx_
arm_func_start getRotDataEx_
getRotDataEx_: ; 0x020BC698
stmdb sp!, {r4-r10,lr}
sub sp, sp, #0x48
ldrh r4, [r3, #0x4]
ldr r5, [r3, #0xc]
ldr r8, [r3, #0x10]
ldr r7, [r2, #0x4]
mov r12, r1, asr #0xc
sub r4, r4, #0x1
mov r6, r0
cmp r12, r4
add r5, r3, r5
add r4, r3, r8
add r8, r3, r7
ldr r7, [r2, #0x0]
bne _020BC780
ands r0, r7, #0xc0000000
beq _020BC6F0
ands r0, r7, #0x40000000
andne r0, r12, #0x1
addne r12, r0, r12, lsr #0x1
andeq r0, r12, #0x3
addeq r12, r0, r12, lsr #0x2
_020BC6F0:
ldr r0, [r3, #0x8]
ands r0, r0, #0x2
movne r7, #0x0
bne _020BC7F4
mov r0, r12, lsl #0x1
ldrh r3, [r8, r0]
mov r0, r6
mov r1, r5
mov r2, r4
bl getRotDataByIdx_
cmp r0, #0x0
addeq sp, sp, #0x48
ldmeqia sp!, {r4-r10,pc}
ldr r9, [r6, #0x14]
ldr r5, [r6, #0x4]
ldr r4, [r6, #0x10]
ldr r2, [r6, #0x8]
mul r1, r5, r9
mul r0, r2, r4
sub r0, r1, r0
ldr r7, [r6, #0xc]
ldr r8, [r6, #0x0]
mov r3, r0, asr #0xc
mul r1, r2, r7
mul r0, r8, r9
sub r2, r1, r0
mul r1, r8, r4
mul r0, r5, r7
sub r0, r1, r0
str r3, [r6, #0x18]
mov r1, r2, asr #0xc
str r1, [r6, #0x1c]
mov r0, r0, asr #0xc
add sp, sp, #0x48
str r0, [r6, #0x20]
ldmia sp!, {r4-r10,pc}
_020BC780:
ands r0, r7, #0xc0000000
beq _020BC7F0
ldr r0, _020BC9C4 ; =0x1FFF0000
ands r2, r7, #0x40000000
and r0, r7, r0
mov r0, r0, lsr #0x10
beq _020BC7C4
cmp r12, r0
movcs r12, r0, lsr #0x1
addcs r7, r12, #0x1
bhs _020BC7F4
ldr r0, _020BC9C8 ; =0x00001FFF
mov r12, r12, lsr #0x1
add r7, r12, #0x1
and r10, r1, r0
mov r9, #0x2
b _020BC800
_020BC7C4:
cmp r12, r0
andcs r0, r12, #0x3
addcs r12, r0, r12, lsr #0x2
addcs r7, r12, #0x1
bhs _020BC7F4
ldr r0, _020BC9CC ; =0x00003FFF
mov r12, r12, lsr #0x2
add r7, r12, #0x1
and r10, r1, r0
mov r9, #0x4
b _020BC800
_020BC7F0:
add r7, r12, #0x1
_020BC7F4:
ldr r0, _020BC9D0 ; =0x00000FFF
mov r9, #0x1
and r10, r1, r0
_020BC800:
mov r0, r12, lsl #0x1
ldrh r3, [r8, r0]
add r0, sp, #0x0
mov r1, r5
mov r2, r4
bl getRotDataByIdx_
mov r1, r7, lsl #0x1
ldrh r3, [r8, r1]
orr r7, r0, #0x0
add r0, sp, #0x24
mov r1, r5
mov r2, r4
bl getRotDataByIdx_
ldr r3, [sp, #0x0]
ldr r1, [sp, #0x24]
mul r2, r3, r9
sub r1, r1, r3
mul r1, r10, r1
add r1, r2, r1, asr #0xc
str r1, [r6, #0x0]
ldr r3, [sp, #0x4]
ldr r1, [sp, #0x28]
mul r2, r3, r9
sub r1, r1, r3
mul r1, r10, r1
add r1, r2, r1, asr #0xc
str r1, [r6, #0x4]
ldr r3, [sp, #0x8]
ldr r1, [sp, #0x2c]
mul r2, r3, r9
sub r1, r1, r3
mul r1, r10, r1
add r1, r2, r1, asr #0xc
str r1, [r6, #0x8]
ldr r3, [sp, #0xc]
ldr r1, [sp, #0x30]
mul r2, r3, r9
sub r1, r1, r3
mul r1, r10, r1
add r1, r2, r1, asr #0xc
str r1, [r6, #0xc]
ldr r2, [sp, #0x10]
ldr r1, [sp, #0x34]
orr r7, r7, r0
sub r0, r1, r2
mul r1, r2, r9
mul r0, r10, r0
add r0, r1, r0, asr #0xc
str r0, [r6, #0x10]
ldr r2, [sp, #0x14]
ldr r0, [sp, #0x38]
mul r1, r2, r9
sub r0, r0, r2
mul r0, r10, r0
add r2, r1, r0, asr #0xc
mov r0, r6
mov r1, r6
str r2, [r6, #0x14]
bl VEC_Normalize
add r0, r6, #0xc
mov r1, r0
bl VEC_Normalize
cmp r7, #0x0
bne _020BC968
ldr r3, [sp, #0x18]
ldr r1, [sp, #0x3c]
mul r2, r3, r9
sub r1, r1, r3
mul r1, r10, r1
add r1, r2, r1, asr #0xc
str r1, [r6, #0x18]
ldr r3, [sp, #0x1c]
ldr r1, [sp, #0x40]
mul r2, r3, r9
sub r1, r1, r3
mul r1, r10, r1
add r1, r2, r1, asr #0xc
str r1, [r6, #0x1c]
ldr r3, [sp, #0x20]
ldr r1, [sp, #0x44]
mul r2, r3, r9
sub r1, r1, r3
mul r1, r10, r1
add r2, r2, r1, asr #0xc
add r0, r6, #0x18
mov r1, r0
str r2, [r6, #0x20]
bl VEC_Normalize
add sp, sp, #0x48
ldmia sp!, {r4-r10,pc}
_020BC968:
ldr r9, [r6, #0x14]
ldr r5, [r6, #0x4]
ldr r8, [r6, #0x0]
ldr r4, [r6, #0x10]
ldr r2, [r6, #0x8]
ldr r7, [r6, #0xc]
mul r1, r5, r9
mul r0, r2, r4
sub r0, r1, r0
mov r3, r0, asr #0xc
mul r1, r2, r7
mul r0, r8, r9
sub r2, r1, r0
mul r1, r8, r4
mul r0, r5, r7
sub r0, r1, r0
str r3, [r6, #0x18]
mov r1, r2, asr #0xc
str r1, [r6, #0x1c]
mov r0, r0, asr #0xc
str r0, [r6, #0x20]
add sp, sp, #0x48
ldmia sp!, {r4-r10,pc}
.balign 4
_020BC9C4: .word 0x1FFF0000
_020BC9C8: .word 0x00001FFF
_020BC9CC: .word 0x00003FFF
_020BC9D0: .word 0x00000FFF
arm_func_end getRotDataEx_
arm_func_start getRotData_
getRotData_: ; 0x020BC9D4
stmdb sp!, {r4-r9,lr}
sub sp, sp, #0x4c
ldr r5, [r3, #0xc]
ldr r4, [r3, #0x10]
ldr r12, [r2, #0x0]
ldr r2, [r2, #0x4]
mov r6, r0
mov r0, r1, asr #0xc
add r5, r3, r5
add r4, r3, r4
add r8, r3, r2
ands r1, r12, #0xc0000000
beq _020BCD40
ldr r1, _020BCDC0 ; =0x1FFF0000
ands r2, r12, #0x40000000
and r1, r12, r1
mov r2, r1, lsr #0x10
beq _020BCA44
ands r1, r0, #0x1
beq _020BCA3C
cmp r0, r2
movhi r0, r2, lsr #0x1
addhi r0, r0, #0x1
bhi _020BCD40
mov r7, r0, lsr #0x1
b _020BCBE8
_020BCA3C:
mov r0, r0, lsr #0x1
b _020BCD40
_020BCA44:
ands r1, r0, #0x3
beq _020BCBE0
cmp r0, r2
addhi r0, r1, r2, lsr #0x2
bhi _020BCD40
ands r1, r0, #0x1
beq _020BCBD8
ands r1, r0, #0x2
movne r9, r0, lsr #0x2
addne r0, r9, #0x1
moveq r0, r0, lsr #0x2
addeq r9, r0, #0x1
mov r0, r0, lsl #0x1
ldrh r3, [r8, r0]
mov r0, r6
mov r1, r5
mov r2, r4
mov r7, #0x0
bl getRotDataByIdx_
mov r1, r9, lsl #0x1
ldrh r3, [r8, r1]
orr r7, r7, r0
add r0, sp, #0x0
mov r1, r5
mov r2, r4
bl getRotDataByIdx_
ldr r3, [sp, #0x0]
ldr r1, [r6, #0x0]
mov r2, #0x3
mla r3, r1, r2, r3
str r3, [r6, #0x0]
ldr r3, [sp, #0x4]
ldr r1, [r6, #0x4]
orr r7, r7, r0
mla r0, r1, r2, r3
str r0, [r6, #0x4]
ldr r3, [sp, #0x8]
ldr r1, [r6, #0x8]
mov r0, r6
mla r3, r1, r2, r3
str r3, [r6, #0x8]
ldr r4, [sp, #0xc]
ldr r3, [r6, #0xc]
mov r1, r6
mla r4, r3, r2, r4
str r4, [r6, #0xc]
ldr r4, [sp, #0x10]
ldr r3, [r6, #0x10]
mla r4, r3, r2, r4
str r4, [r6, #0x10]
ldr r4, [sp, #0x14]
ldr r3, [r6, #0x14]
mla r2, r3, r2, r4
str r2, [r6, #0x14]
bl VEC_Normalize
add r0, r6, #0xc
mov r1, r0
bl VEC_Normalize
cmp r7, #0x0
bne _020BCB7C
ldr r1, [sp, #0x18]
ldr r0, [r6, #0x18]
mov r2, #0x3
mla r1, r0, r2, r1
str r1, [r6, #0x18]
ldr r3, [sp, #0x1c]
ldr r1, [r6, #0x1c]
add r0, r6, #0x18
mla r3, r1, r2, r3
str r3, [r6, #0x1c]
ldr r4, [sp, #0x20]
ldr r3, [r6, #0x20]
mov r1, r0
mla r2, r3, r2, r4
str r2, [r6, #0x20]
bl VEC_Normalize
add sp, sp, #0x4c
ldmia sp!, {r4-r9,pc}
_020BCB7C:
ldr r12, [r6, #0x14]
ldr r5, [r6, #0x4]
ldr r4, [r6, #0x10]
ldr r2, [r6, #0x8]
mul r1, r5, r12
mul r0, r2, r4
sub r0, r1, r0
ldr r7, [r6, #0xc]
ldr r8, [r6, #0x0]
mov r3, r0, asr #0xc
mul r1, r2, r7
mul r0, r8, r12
sub r2, r1, r0
mul r1, r8, r4
mul r0, r5, r7
sub r0, r1, r0
str r3, [r6, #0x18]
mov r1, r2, asr #0xc
str r1, [r6, #0x1c]
mov r0, r0, asr #0xc
add sp, sp, #0x4c
str r0, [r6, #0x20]
ldmia sp!, {r4-r9,pc}
_020BCBD8:
mov r7, r0, lsr #0x2
b _020BCBE8
_020BCBE0:
mov r0, r0, lsr #0x2
b _020BCD40
_020BCBE8:
mov r0, r7, lsl #0x1
ldrh r3, [r8, r0]
mov r0, r6
mov r1, r5
mov r2, r4
bl getRotDataByIdx_
add r1, r8, r7, lsl #0x1
ldrh r3, [r1, #0x2]
orr r7, r0, #0x0
add r0, sp, #0x24
mov r1, r5
mov r2, r4
bl getRotDataByIdx_
ldr r2, [r6, #0x0]
ldr r1, [sp, #0x24]
orr r7, r7, r0
add r0, r2, r1
str r0, [r6, #0x0]
ldr r2, [r6, #0x4]
ldr r1, [sp, #0x28]
mov r0, r6
add r1, r2, r1
str r1, [r6, #0x4]
ldr r3, [r6, #0x8]
ldr r2, [sp, #0x2c]
mov r1, r6
add r2, r3, r2
str r2, [r6, #0x8]
ldr r3, [r6, #0xc]
ldr r2, [sp, #0x30]
add r2, r3, r2
str r2, [r6, #0xc]
ldr r3, [r6, #0x10]
ldr r2, [sp, #0x34]
add r2, r3, r2
str r2, [r6, #0x10]
ldr r3, [r6, #0x14]
ldr r2, [sp, #0x38]
add r2, r3, r2
str r2, [r6, #0x14]
bl VEC_Normalize
add r0, r6, #0xc
mov r1, r0
bl VEC_Normalize
cmp r7, #0x0
bne _020BCCE4
ldr r2, [r6, #0x18]
ldr r1, [sp, #0x3c]
add r0, r6, #0x18
add r1, r2, r1
str r1, [r6, #0x18]
ldr r3, [r6, #0x1c]
ldr r2, [sp, #0x40]
mov r1, r0
add r2, r3, r2
str r2, [r6, #0x1c]
ldr r3, [r6, #0x20]
ldr r2, [sp, #0x44]
add r2, r3, r2
str r2, [r6, #0x20]
bl VEC_Normalize
add sp, sp, #0x4c
ldmia sp!, {r4-r9,pc}
_020BCCE4:
ldr r12, [r6, #0x14]
ldr r5, [r6, #0x4]
ldr r4, [r6, #0x10]
ldr r2, [r6, #0x8]
mul r1, r5, r12
mul r0, r2, r4
sub r0, r1, r0
ldr r7, [r6, #0xc]
ldr r8, [r6, #0x0]
mov r3, r0, asr #0xc
mul r1, r2, r7
mul r0, r8, r12
sub r2, r1, r0
mul r1, r8, r4
mul r0, r5, r7
sub r0, r1, r0
str r3, [r6, #0x18]
mov r1, r2, asr #0xc
str r1, [r6, #0x1c]
mov r0, r0, asr #0xc
add sp, sp, #0x4c
str r0, [r6, #0x20]
ldmia sp!, {r4-r9,pc}
_020BCD40:
mov r0, r0, lsl #0x1
ldrh r3, [r8, r0]
mov r0, r6
mov r1, r5
mov r2, r4
bl getRotDataByIdx_
cmp r0, #0x0
addeq sp, sp, #0x4c
ldmeqia sp!, {r4-r9,pc}
ldr r12, [r6, #0x14]
ldr r5, [r6, #0x4]
ldr r8, [r6, #0x0]
ldr r4, [r6, #0x10]
ldr r2, [r6, #0x8]
ldr r7, [r6, #0xc]
mul r1, r5, r12
mul r0, r2, r4
sub r0, r1, r0
mov r3, r0, asr #0xc
mul r1, r2, r7
mul r0, r8, r12
sub r2, r1, r0
mul r1, r8, r4
mul r0, r5, r7
sub r0, r1, r0
str r3, [r6, #0x18]
mov r1, r2, asr #0xc
str r1, [r6, #0x1c]
mov r0, r0, asr #0xc
str r0, [r6, #0x20]
add sp, sp, #0x4c
ldmia sp!, {r4-r9,pc}
.balign 4
_020BCDC0: .word 0x1FFF0000
arm_func_end getRotData_
arm_func_start getScaleDataEx_
getScaleDataEx_: ; 0x020BCDC4
stmdb sp!, {r4-r7,lr}
sub sp, sp, #0x4
ldrh r4, [r3, #0x4]
ldr r6, [r2, #0x4]
mov r5, r1, asr #0xc
sub r4, r4, #0x1
cmp r5, r4
add r6, r3, r6
ldr r2, [r2, #0x0]
bne _020BCE58
ands r4, r2, #0xc0000000
beq _020BCE08
ands r4, r2, #0x40000000
andne r4, r5, #0x1
addne r5, r4, r5, lsr #0x1
andeq r4, r5, #0x3
addeq r5, r4, r5, lsr #0x2
_020BCE08:
ldr r3, [r3, #0x8]
ands r3, r3, #0x2
movne r4, #0x0
bne _020BCED4
ands r1, r2, #0x20000000
ldreq r2, [r6, r5, lsl #0x3]
addeq r1, r6, r5, lsl #0x3
streq r2, [r0, #0x0]
ldreq r1, [r1, #0x4]
addeq sp, sp, #0x4
streq r1, [r0, #0x4]
ldmeqia sp!, {r4-r7,pc}
mov r1, r5, lsl #0x2
ldrsh r2, [r6, r1]
add r1, r6, r5, lsl #0x2
add sp, sp, #0x4
str r2, [r0, #0x0]
ldrsh r1, [r1, #0x2]
str r1, [r0, #0x4]
ldmia sp!, {r4-r7,pc}
_020BCE58:
ands r3, r2, #0xc0000000
beq _020BCED0
ldr r3, _020BCF60 ; =0x1FFF0000
ands r4, r2, #0x40000000
and r3, r2, r3
mov r3, r3, lsr #0x10
beq _020BCEA0
cmp r5, r3
movcs r5, r3, lsr #0x1
addcs r4, r5, #0x1
bhs _020BCED4
ldr r3, _020BCF64 ; =0x00001FFF
mov r5, r5, lsr #0x1
add r4, r5, #0x1
and lr, r1, r3
mov r12, #0x2
mov r3, #0x1
b _020BCEE4
_020BCEA0:
cmp r5, r3
andcs r3, r5, #0x3
addcs r5, r3, r5, lsr #0x2
addcs r4, r5, #0x1
bhs _020BCED4
ldr r3, _020BCF68 ; =0x00003FFF
mov r5, r5, lsr #0x2
add r4, r5, #0x1
and lr, r1, r3
mov r12, #0x4
mov r3, #0x2
b _020BCEE4
_020BCED0:
add r4, r5, #0x1
_020BCED4:
ldr r3, _020BCF6C ; =0x00000FFF
mov r12, #0x1
and lr, r1, r3
mov r3, #0x0
_020BCEE4:
ands r1, r2, #0x20000000
beq _020BCF10
mov r2, r5, lsl #0x2
add r1, r6, r5, lsl #0x2
mov r5, r4, lsl #0x2
add r4, r6, r4, lsl #0x2
ldrsh r2, [r6, r2]
ldrsh r1, [r1, #0x2]
ldrsh r5, [r6, r5]
ldrsh r4, [r4, #0x2]
b _020BCF28
_020BCF10:
add r1, r6, r5, lsl #0x3
add r7, r6, r4, lsl #0x3
ldr r2, [r6, r5, lsl #0x3]
ldr r1, [r1, #0x4]
ldr r5, [r6, r4, lsl #0x3]
ldr r4, [r7, #0x4]
_020BCF28:
sub r5, r5, r2
sub r4, r4, r1
mul r6, r2, r12
mul r2, lr, r5
add r2, r6, r2, asr #0xc
mov r5, r2, asr r3
mul r2, r1, r12
mul r1, lr, r4
add r1, r2, r1, asr #0xc
mov r1, r1, asr r3
str r5, [r0, #0x0]
str r1, [r0, #0x4]
add sp, sp, #0x4
ldmia sp!, {r4-r7,pc}
.balign 4
_020BCF60: .word 0x1FFF0000
_020BCF64: .word 0x00001FFF
_020BCF68: .word 0x00003FFF
_020BCF6C: .word 0x00000FFF
arm_func_end getScaleDataEx_
arm_func_start getScaleData_
getScaleData_: ; 0x020BCF70
stmdb sp!, {r4-r5,lr}
sub sp, sp, #0x4
ldr r4, [r2, #0x4]
ldr r12, [r2, #0x0]
mov r1, r1, asr #0xc
add r3, r3, r4
ands r2, r12, #0xc0000000
beq _020BD0D0
ldr r2, _020BD184 ; =0x1FFF0000
ands r4, r12, #0x40000000
and r2, r12, r2
mov r4, r2, lsr #0x10
beq _020BCFCC
ands r2, r1, #0x1
beq _020BCFC4
cmp r1, r4
movhi r1, r4, lsr #0x1
addhi r1, r1, #0x1
bhi _020BD0D0
mov r2, r1, lsr #0x1
b _020BD110
_020BCFC4:
mov r1, r1, lsr #0x1
b _020BD0D0
_020BCFCC:
ands r2, r1, #0x3
beq _020BD0CC
cmp r1, r4
addhi r1, r2, r4, lsr #0x2
bhi _020BD0D0
ands r2, r1, #0x1
beq _020BD0C4
ands r2, r1, #0x2
movne r1, r1, lsr #0x2
addne r2, r1, #0x1
moveq r2, r1, lsr #0x2
addeq r1, r2, #0x1
ands r4, r12, #0x20000000
beq _020BD04C
mov r5, r2, lsl #0x2
mov r4, r1, lsl #0x2
ldrsh r12, [r3, r5]
ldrsh r5, [r3, r4]
add r2, r3, r2, lsl #0x2
add r4, r12, r12, lsl #0x1
add r4, r5, r4
mov r4, r4, asr #0x2
str r4, [r0, #0x0]
add r1, r3, r1, lsl #0x2
ldrsh r3, [r2, #0x2]
ldrsh r2, [r1, #0x2]
add sp, sp, #0x4
add r1, r3, r3, lsl #0x1
add r1, r2, r1
mov r1, r1, asr #0x2
str r1, [r0, #0x4]
ldmia sp!, {r4-r5,pc}
_020BD04C:
ldr r5, [r3, r2, lsl #0x3]
ldr r4, [r3, r1, lsl #0x3]
mov r12, r5, asr #0x1f
mov r12, r12, lsl #0x1
mov lr, r5, lsl #0x1
orr r12, r12, r5, lsr #0x1f
adds lr, lr, r5
adc r12, r12, r5, asr #0x1f
adds lr, lr, r4
adc r12, r12, r4, asr #0x1f
mov lr, lr, lsr #0x2
orr lr, lr, r12, lsl #0x1e
str lr, [r0, #0x0]
add r2, r3, r2, lsl #0x3
ldr r12, [r2, #0x4]
add r1, r3, r1, lsl #0x3
mov r2, r12, asr #0x1f
mov r2, r2, lsl #0x1
mov r3, r12, lsl #0x1
ldr r1, [r1, #0x4]
orr r2, r2, r12, lsr #0x1f
adds r3, r3, r12
adc r2, r2, r12, asr #0x1f
adds r3, r3, r1
adc r1, r2, r1, asr #0x1f
mov r2, r3, lsr #0x2
orr r2, r2, r1, lsl #0x1e
str r2, [r0, #0x4]
add sp, sp, #0x4
ldmia sp!, {r4-r5,pc}
_020BD0C4:
mov r2, r1, lsr #0x2
b _020BD110
_020BD0CC:
mov r1, r1, lsr #0x2
_020BD0D0:
ands r2, r12, #0x20000000
ldreq r2, [r3, r1, lsl #0x3]
addeq r1, r3, r1, lsl #0x3
streq r2, [r0, #0x0]
ldreq r1, [r1, #0x4]
addeq sp, sp, #0x4
streq r1, [r0, #0x4]
ldmeqia sp!, {r4-r5,pc}
mov r2, r1, lsl #0x2
ldrsh r2, [r3, r2]
add r1, r3, r1, lsl #0x2
add sp, sp, #0x4
str r2, [r0, #0x0]
ldrsh r1, [r1, #0x2]
str r1, [r0, #0x4]
ldmia sp!, {r4-r5,pc}
_020BD110:
ands r1, r12, #0x20000000
beq _020BD150
mov r1, r2, lsl #0x2
add r12, r3, r2, lsl #0x2
ldrsh r2, [r3, r1]
ldrsh r1, [r12, #0x4]
add sp, sp, #0x4
add r1, r2, r1
mov r1, r1, asr #0x1
str r1, [r0, #0x0]
ldrsh r2, [r12, #0x2]
ldrsh r1, [r12, #0x6]
add r1, r2, r1
mov r1, r1, asr #0x1
str r1, [r0, #0x4]
ldmia sp!, {r4-r5,pc}
_020BD150:
add r12, r3, r2, lsl #0x3
ldr r2, [r3, r2, lsl #0x3]
ldr r1, [r12, #0x8]
add r1, r2, r1
mov r1, r1, asr #0x1
str r1, [r0, #0x0]
ldr r2, [r12, #0x4]
ldr r1, [r12, #0xc]
add r1, r2, r1
mov r1, r1, asr #0x1
str r1, [r0, #0x4]
add sp, sp, #0x4
ldmia sp!, {r4-r5,pc}
.balign 4
_020BD184: .word 0x1FFF0000
arm_func_end getScaleData_
arm_func_start getTransDataEx_
getTransDataEx_: ; 0x020BD188
stmdb sp!, {r4-r5,lr}
sub sp, sp, #0x4
ldrh r4, [r3, #0x4]
ldr lr, [r2, #0x4]
mov r12, r1, asr #0xc
sub r4, r4, #0x1
cmp r12, r4
add r4, r3, lr
ldr lr, [r2, #0x0]
bne _020BD230
ands r2, lr, #0xc0000000
beq _020BD1CC
ands r2, lr, #0x40000000
andne r2, r12, #0x1
addne r12, r2, r12, lsr #0x1
andeq r2, r12, #0x3
addeq r12, r2, r12, lsr #0x2
_020BD1CC:
ldr r2, [r3, #0x8]
ands r2, r2, #0x2
beq _020BD210
ldr r2, _020BD2E8 ; =0x00000FFF
ands r3, lr, #0x20000000
and r3, r1, r2
movne r1, r12, lsl #0x1
ldrnesh r2, [r4, r1]
ldrnesh r1, [r4, #0x0]
add sp, sp, #0x4
ldreq r2, [r4, r12, lsl #0x2]
ldreq r1, [r4, #0x0]
sub r1, r1, r2
mul r1, r3, r1
add r1, r2, r1, asr #0xc
str r1, [r0, #0x0]
ldmia sp!, {r4-r5,pc}
_020BD210:
ands r1, lr, #0x20000000
movne r1, r12, lsl #0x1
ldrnesh r1, [r4, r1]
add sp, sp, #0x4
strne r1, [r0, #0x0]
ldreq r1, [r4, r12, lsl #0x2]
streq r1, [r0, #0x0]
ldmia sp!, {r4-r5,pc}
_020BD230:
ands r2, lr, #0xc0000000
beq _020BD298
ldr r2, _020BD2EC ; =0x1FFF0000
ands r3, lr, #0x40000000
and r2, lr, r2
mov r2, r2, lsr #0x10
beq _020BD270
cmp r12, r2
movcs r12, r2, lsr #0x1
bhs _020BD298
ldr r2, _020BD2F0 ; =0x00001FFF
mov r12, r12, lsr #0x1
and r5, r1, r2
mov r2, #0x2
mov r1, #0x1
b _020BD2A8
_020BD270:
cmp r12, r2
andcs r2, r12, #0x3
addcs r12, r2, r12, lsr #0x2
bhs _020BD298
ldr r2, _020BD2F4 ; =0x00003FFF
mov r12, r12, lsr #0x2
and r5, r1, r2
mov r2, #0x4
mov r1, #0x2
b _020BD2A8
_020BD298:
ldr r3, _020BD2E8 ; =0x00000FFF
mov r2, #0x1
and r5, r1, r3
mov r1, #0x0
_020BD2A8:
ands r3, lr, #0x20000000
addne r3, r4, r12, lsl #0x1
movne lr, r12, lsl #0x1
ldrnesh r12, [r4, lr]
ldrnesh r3, [r3, #0x2]
addeq r3, r4, r12, lsl #0x2
ldreq r12, [r4, r12, lsl #0x2]
ldreq r3, [r3, #0x4]
mul r4, r12, r2
sub r3, r3, r12
mul r2, r5, r3
add r2, r4, r2, asr #0xc
mov r1, r2, asr r1
str r1, [r0, #0x0]
add sp, sp, #0x4
ldmia sp!, {r4-r5,pc}
.balign 4
_020BD2E8: .word 0x00000FFF
_020BD2EC: .word 0x1FFF0000
_020BD2F0: .word 0x00001FFF
_020BD2F4: .word 0x00003FFF
arm_func_end getTransDataEx_
arm_func_start getTransData_
getTransData_: ; 0x020BD2F8
stmdb sp!, {lr}
sub sp, sp, #0x4
ldr r12, [r2, #0x4]
ldr r2, [r2, #0x0]
mov r1, r1, asr #0xc
add r3, r3, r12
ands r12, r2, #0xc0000000
beq _020BD44C
ldr ip, _020BD46C ; =0x1FFF0000
ands lr, r2, #0x40000000
and r12, r2, r12
mov lr, r12, lsr #0x10
beq _020BD354
ands r12, r1, #0x1
beq _020BD34C
cmp r1, lr
movhi r1, lr, lsr #0x1
addhi r1, r1, #0x1
bhi _020BD44C
mov r12, r1, lsr #0x1
b _020BD400
_020BD34C:
mov r1, r1, lsr #0x1
b _020BD44C
_020BD354:
ands r12, r1, #0x3
beq _020BD3F8
cmp r1, lr
addhi r1, r12, lr, lsr #0x2
bhi _020BD44C
ands r12, r1, #0x1
beq _020BD3F0
ands r12, r1, #0x2
movne lr, r1, lsr #0x2
addne r12, lr, #0x1
moveq r12, r1, lsr #0x2
addeq lr, r12, #0x1
ands r1, r2, #0x20000000
beq _020BD3B4
mov r2, r12, lsl #0x1
mov r1, lr, lsl #0x1
ldrsh r12, [r3, r2]
ldrsh r2, [r3, r1]
mov r1, #0x3
add sp, sp, #0x4
smlabb r1, r12, r1, r2
mov r1, r1, asr #0x2
str r1, [r0, #0x0]
ldmia sp!, {pc}
_020BD3B4:
ldr r12, [r3, r12, lsl #0x2]
ldr r1, [r3, lr, lsl #0x2]
mov r2, r12, asr #0x1f
mov r2, r2, lsl #0x1
mov r3, r12, lsl #0x1
orr r2, r2, r12, lsr #0x1f
adds r3, r3, r12
adc r2, r2, r12, asr #0x1f
adds r3, r3, r1
adc r1, r2, r1, asr #0x1f
mov r2, r3, lsr #0x2
orr r2, r2, r1, lsl #0x1e
str r2, [r0, #0x0]
add sp, sp, #0x4
ldmia sp!, {pc}
_020BD3F0:
mov r12, r1, lsr #0x2
b _020BD400
_020BD3F8:
mov r1, r1, lsr #0x2
b _020BD44C
_020BD400:
ands r1, r2, #0x20000000
beq _020BD42C
mov r2, r12, lsl #0x1
add r1, r3, r12, lsl #0x1
ldrsh r2, [r3, r2]
ldrsh r1, [r1, #0x2]
add sp, sp, #0x4
add r1, r2, r1
mov r1, r1, asr #0x1
str r1, [r0, #0x0]
ldmia sp!, {pc}
_020BD42C:
add r1, r3, r12, lsl #0x2
ldr r2, [r3, r12, lsl #0x2]
ldr r1, [r1, #0x4]
mov r2, r2, asr #0x1
add r1, r2, r1, asr #0x1
str r1, [r0, #0x0]
add sp, sp, #0x4
ldmia sp!, {pc}
_020BD44C:
ands r2, r2, #0x20000000
movne r1, r1, lsl #0x1
ldrnesh r1, [r3, r1]
strne r1, [r0, #0x0]
ldreq r1, [r3, r1, lsl #0x2]
streq r1, [r0, #0x0]
add sp, sp, #0x4
ldmia sp!, {pc}
.balign 4
_020BD46C: .word 0x1FFF0000
arm_func_end getTransData_
arm_func_start getJntSRTAnmResult_
getJntSRTAnmResult_: ; 0x020BD470
stmdb sp!, {r4-r11,lr}
sub sp, sp, #0x34
mov r9, r0
add r0, r9, r1, lsl #0x1
ldrh r0, [r0, #0x14]
mov r7, r3
mov r8, r2
ldr r5, [r9, r0]
add r1, r9, r0
ands r0, r5, #0x1
movne r0, #0x7
strne r0, [r7, #0x0]
bne _020BD814
ldr r0, _020BD848 ; =0x00000FFF
add r4, r1, #0x4
ands r0, r8, r0
beq _020BD4C4
ldr r0, [r9, #0x8]
ands r0, r0, #0x1
movne r6, #0x1
bne _020BD4C8
_020BD4C4:
mov r6, #0x0
_020BD4C8:
mov r0, #0x0
str r0, [r7, #0x0]
ands r0, r5, #0x6
bne _020BD5C0
ands r0, r5, #0x8
bne _020BD51C
cmp r6, #0x0
beq _020BD500
mov r1, r8
mov r2, r4
mov r3, r9
add r0, r7, #0x4c
bl getTransDataEx_
b _020BD514
_020BD500:
mov r1, r8
mov r2, r4
mov r3, r9
add r0, r7, #0x4c
bl getTransData_
_020BD514:
add r4, r4, #0x8
b _020BD524
_020BD51C:
ldr r0, [r4], #0x4
str r0, [r7, #0x4c]
_020BD524:
ands r0, r5, #0x10
bne _020BD568
cmp r6, #0x0
beq _020BD54C
mov r1, r8
mov r2, r4
mov r3, r9
add r0, r7, #0x50
bl getTransDataEx_
b _020BD560
_020BD54C:
mov r1, r8
mov r2, r4
mov r3, r9
add r0, r7, #0x50
bl getTransData_
_020BD560:
add r4, r4, #0x8
b _020BD570
_020BD568:
ldr r0, [r4], #0x4
str r0, [r7, #0x50]
_020BD570:
ands r0, r5, #0x20
bne _020BD5B4
cmp r6, #0x0
beq _020BD598
mov r1, r8
mov r2, r4
mov r3, r9
add r0, r7, #0x54
bl getTransDataEx_
b _020BD5AC
_020BD598:
mov r1, r8
mov r2, r4
mov r3, r9
add r0, r7, #0x54
bl getTransData_
_020BD5AC:
add r4, r4, #0x8
b _020BD5DC
_020BD5B4:
ldr r0, [r4], #0x4
str r0, [r7, #0x54]
b _020BD5DC
_020BD5C0:
ands r0, r5, #0x2
ldrne r0, [r7, #0x0]
orrne r0, r0, #0x4
strne r0, [r7, #0x0]
bne _020BD5DC
mov r0, r7
bl getMdlTrans_
_020BD5DC:
ands r0, r5, #0xc0
bne _020BD6A8
ands r0, r5, #0x100
bne _020BD628
cmp r6, #0x0
beq _020BD60C
mov r1, r8
mov r2, r4
mov r3, r9
add r0, r7, #0x28
bl getRotDataEx_
b _020BD620
_020BD60C:
mov r1, r8
mov r2, r4
mov r3, r9
add r0, r7, #0x28
bl getRotData_
_020BD620:
add r4, r4, #0x8
b _020BD6C4
_020BD628:
ldr r1, [r9, #0xc]
ldr r2, [r9, #0x10]
ldr r3, [r4, #0x0]
add r0, r7, #0x28
add r1, r9, r1
add r2, r9, r2
bl getRotDataByIdx_
cmp r0, #0x0
beq _020BD6A0
ldr r12, [r7, #0x3c]
ldr r0, [r7, #0x2c]
ldr r3, [r7, #0x28]
ldr r11, [r7, #0x38]
ldr r1, [r7, #0x30]
ldr r2, [r7, #0x34]
mul r10, r0, r12
mul lr, r1, r11
sub r10, r10, lr
mov r10, r10, asr #0xc
mul lr, r1, r2
mul r1, r3, r12
sub r1, lr, r1
mul r11, r3, r11
mul r2, r0, r2
sub r0, r11, r2
str r10, [r7, #0x40]
mov r1, r1, asr #0xc
str r1, [r7, #0x44]
mov r0, r0, asr #0xc
str r0, [r7, #0x48]
_020BD6A0:
add r4, r4, #0x4
b _020BD6C4
_020BD6A8:
ands r0, r5, #0x40
ldrne r0, [r7, #0x0]
orrne r0, r0, #0x2
strne r0, [r7, #0x0]
bne _020BD6C4
mov r0, r7
bl getMdlRot_
_020BD6C4:
ands r0, r5, #0x600
bne _020BD7F0
ands r0, r5, #0x800
bne _020BD71C
cmp r6, #0x0
beq _020BD6F4
add r0, sp, #0x0
mov r1, r8
mov r2, r4
mov r3, r9
bl getScaleDataEx_
b _020BD708
_020BD6F4:
add r0, sp, #0x0
mov r1, r8
mov r2, r4
mov r3, r9
bl getScaleData_
_020BD708:
ldr r1, [sp, #0x0]
ldr r0, [sp, #0x4]
str r1, [sp, #0x18]
str r0, [sp, #0x24]
b _020BD72C
_020BD71C:
ldr r0, [r4, #0x0]
str r0, [sp, #0x18]
ldr r0, [r4, #0x4]
str r0, [sp, #0x24]
_020BD72C:
ands r0, r5, #0x1000
bne _020BD77C
cmp r6, #0x0
beq _020BD754
add r0, sp, #0x8
mov r1, r8
mov r3, r9
add r2, r4, #0x8
bl getScaleDataEx_
b _020BD768
_020BD754:
add r0, sp, #0x8
mov r1, r8
mov r3, r9
add r2, r4, #0x8
bl getScaleData_
_020BD768:
ldr r1, [sp, #0x8]
ldr r0, [sp, #0xc]
str r1, [sp, #0x1c]
str r0, [sp, #0x28]
b _020BD78C
_020BD77C:
ldr r0, [r4, #0x8]
str r0, [sp, #0x1c]
ldr r0, [r4, #0xc]
str r0, [sp, #0x28]
_020BD78C:
ands r0, r5, #0x2000
bne _020BD7DC
cmp r6, #0x0
beq _020BD7B4
add r0, sp, #0x10
mov r1, r8
mov r3, r9
add r2, r4, #0x10
bl getScaleDataEx_
b _020BD7C8
_020BD7B4:
add r0, sp, #0x10
mov r1, r8
mov r3, r9
add r2, r4, #0x10
bl getScaleData_
_020BD7C8:
ldr r1, [sp, #0x10]
ldr r0, [sp, #0x14]
str r1, [sp, #0x20]
str r0, [sp, #0x2c]
b _020BD814
_020BD7DC:
ldr r0, [r4, #0x10]
str r0, [sp, #0x20]
ldr r0, [r4, #0x14]
str r0, [sp, #0x2c]
b _020BD814
_020BD7F0:
ands r0, r5, #0x200
ldrne r0, [r7, #0x0]
orrne r0, r0, #0x1
strne r0, [r7, #0x0]
bne _020BD814
mov r0, r7
bl getMdlScale_
add sp, sp, #0x34
ldmia sp!, {r4-r11,pc}
_020BD814:
ldr r0, [r7, #0x0]
add r1, sp, #0x18
ands r0, r0, #0x1
ldr r0, _020BD84C ; =NNS_G3dRS
movne r3, #0x4
ldr r4, [r0, #0x0]
moveq r3, #0x0
ldr r2, [r4, #0x0]
ldr r4, [r4, #0xe8]
mov r0, r7
blx r4
add sp, sp, #0x34
ldmia sp!, {r4-r11,pc}
.balign 4
_020BD848: .word 0x00000FFF
_020BD84C: .word NNS_G3dRS
arm_func_end getJntSRTAnmResult_
arm_func_start getMdlRot_
getMdlRot_: ; 0x020BD850
stmdb sp!, {r4-r8,lr}
ldr r1, _020BD990 ; =NNS_G3dRS
mov r8, r0
ldr r0, [r1, #0x0]
ldr r3, [r0, #0xd4]
ldr r0, [r0, #0x0]
ldrh r2, [r3, #0x6]
ldrb r0, [r0, #0x1]
ldrh r1, [r3, r2]
add r2, r3, r2
mla r0, r1, r0, r2
ldr r0, [r0, #0x4]
ldrh r2, [r3, r0]
add r4, r3, r0
add r1, r4, #0x4
ands r0, r2, #0x1
addeq r1, r1, #0xc
ands r0, r2, #0x2
bne _020BD980
ands r0, r2, #0x8
beq _020BD934
and r2, r2, #0xf0
add r0, r8, #0x28
mov r5, r2, asr #0x4
ldrsh r7, [r1, #0x0]
ldrsh r6, [r1, #0x2]
bl MI_Zero36B
ldrh r0, [r4, #0x0]
add r1, r8, r5, lsl #0x2
ands r0, r0, #0x100
movne r0, #0x1000
rsbne r2, r0, #0x0
moveq r2, #0x1000
ldr r0, _020BD994 ; =pivotUtil_
str r2, [r1, #0x28]
ldrb r1, [r0, r5, lsl #0x2]
ldr r0, _020BD998 ; =pivotUtil_ + 1
add r1, r8, r1, lsl #0x2
str r7, [r1, #0x28]
ldrb r0, [r0, r5, lsl #0x2]
add r0, r8, r0, lsl #0x2
str r6, [r0, #0x28]
ldrh r0, [r4, #0x0]
ands r0, r0, #0x200
ldr r0, _020BD99C ; =pivotUtil_ + 2
rsbne r6, r6, #0x0
ldrb r0, [r0, r5, lsl #0x2]
add r0, r8, r0, lsl #0x2
str r6, [r0, #0x28]
ldrh r0, [r4, #0x0]
ands r0, r0, #0x400
ldr r0, _020BD9A0 ; =pivotUtil_ + 3
rsbne r7, r7, #0x0
ldrb r0, [r0, r5, lsl #0x2]
add r0, r8, r0, lsl #0x2
str r7, [r0, #0x28]
ldmia sp!, {r4-r8,pc}
_020BD934:
ldrsh r0, [r4, #0x2]
str r0, [r8, #0x28]
ldrsh r0, [r1, #0x0]
str r0, [r8, #0x2c]
ldrsh r0, [r1, #0x2]
str r0, [r8, #0x30]
ldrsh r0, [r1, #0x4]
str r0, [r8, #0x34]
ldrsh r0, [r1, #0x6]
str r0, [r8, #0x38]
ldrsh r0, [r1, #0x8]
str r0, [r8, #0x3c]
ldrsh r0, [r1, #0xa]
str r0, [r8, #0x40]
ldrsh r0, [r1, #0xc]
str r0, [r8, #0x44]
ldrsh r0, [r1, #0xe]
str r0, [r8, #0x48]
ldmia sp!, {r4-r8,pc}
_020BD980:
ldr r0, [r8, #0x0]
orr r0, r0, #0x2
str r0, [r8, #0x0]
ldmia sp!, {r4-r8,pc}
.balign 4
_020BD990: .word NNS_G3dRS
_020BD994: .word pivotUtil_
_020BD998: .word pivotUtil_ + 1
_020BD99C: .word pivotUtil_ + 2
_020BD9A0: .word pivotUtil_ + 3
arm_func_end getMdlRot_
arm_func_start getMdlScale_
getMdlScale_: ; 0x020BD9A4
stmdb sp!, {r4,lr}
ldr r1, _020BDA04 ; =NNS_G3dRS
ldr r12, [r1, #0x0]
ldr r4, [r12, #0xd4]
ldr r2, [r12, #0x0]
ldrh lr, [r4, #0x6]
ldrb r1, [r2, #0x1]
ldrh r3, [r4, lr]
add lr, r4, lr
mla r1, r3, r1, lr
ldr r1, [r1, #0x4]
ldrh r3, [r4, r1]
add r1, r4, r1
add r1, r1, #0x4
ands lr, r3, #0x1
addeq r1, r1, #0xc
ands lr, r3, #0x2
bne _020BD9F8
ands lr, r3, #0x8
addne r1, r1, #0x4
addeq r1, r1, #0x10
_020BD9F8:
ldr r12, [r12, #0xe8]
blx r12
ldmia sp!, {r4,pc}
.balign 4
_020BDA04: .word NNS_G3dRS
arm_func_end getMdlScale_
arm_func_start getMdlTrans_
getMdlTrans_: ; 0x020BDA08
ldr r1, _020BDA6C ; =NNS_G3dRS
ldr r1, [r1, #0x0]
ldr r12, [r1, #0xd4]
ldr r1, [r1, #0x0]
ldrh r3, [r12, #0x6]
ldrb r1, [r1, #0x1]
ldrh r2, [r12, r3]
add r3, r12, r3
mla r1, r2, r1, r3
ldr r2, [r1, #0x4]
ldrh r1, [r12, r2]
add r2, r12, r2
ands r1, r1, #0x1
ldrne r1, [r0, #0x0]
orrne r1, r1, #0x4
strne r1, [r0, #0x0]
bxne lr
ldr r1, [r2, #0x4]
add r2, r2, #0x4
str r1, [r0, #0x4c]
ldr r1, [r2, #0x4]
str r1, [r0, #0x50]
ldr r1, [r2, #0x8]
str r1, [r0, #0x54]
bx lr
.balign 4
_020BDA6C: .word NNS_G3dRS
arm_func_end getMdlTrans_
arm_func_start NNSi_G3dAnmCalcNsBca
NNSi_G3dAnmCalcNsBca: ; 0x020BDA70
stmdb sp!, {lr}
sub sp, sp, #0x4
mov r3, r0
ldr r0, [r1, #0x8]
ldr r12, [r1, #0x0]
ldrh r1, [r0, #0x4]
mov r1, r1, lsl #0xc
cmp r12, r1
subge r12, r1, #0x1
bge _020BDAA0
cmp r12, #0x0
movlt r12, #0x0
_020BDAA0:
mov r1, r2
mov r2, r12
bl getJntSRTAnmResult_
add sp, sp, #0x4
ldmia sp!, {pc}
arm_func_end NNSi_G3dAnmCalcNsBca
arm_func_start NNSi_G3dAnmObjInitNsBca
NNSi_G3dAnmObjInitNsBca: ; 0x020BDAB4
stmdb sp!, {r4-r5,lr}
sub sp, sp, #0x4
mov r5, r0
mov r4, r1
ldr r0, _020BDB3C ; =NNS_G3dFuncAnmJntNsBcaDefault
str r4, [r5, #0x8]
ldr r0, [r0, #0x0]
add r1, r5, #0x1a
str r0, [r5, #0xc]
ldrb r2, [r2, #0x17]
mov r0, #0x0
strb r2, [r5, #0x19]
ldrb r2, [r5, #0x19]
mov r2, r2, lsl #0x1
bl MIi_CpuClear16
ldrh r0, [r4, #0x6]
add r2, r4, #0x14
mov r3, #0x0
cmp r0, #0x0
addls sp, sp, #0x4
ldmlsia sp!, {r4-r5,pc}
_020BDB08:
mov r0, r3, lsl #0x1
ldrh r1, [r2, r0]
add r0, r5, r3, lsl #0x1
add r3, r3, #0x1
ldr r1, [r4, r1]
mov r1, r1, lsr #0x18
orr r1, r1, #0x100
strh r1, [r0, #0x1a]
ldrh r0, [r4, #0x6]
cmp r3, r0
blo _020BDB08
add sp, sp, #0x4
ldmia sp!, {r4-r5,pc}
.balign 4
_020BDB3C: .word NNS_G3dFuncAnmJntNsBcaDefault
arm_func_end NNSi_G3dAnmObjInitNsBca
|