prime/asm/Dolphin/GBA/GBAXfer.s

227 lines
11 KiB
ArmAsm
Raw Normal View History

.include "macros.inc"
2022-04-02 22:25:50 +00:00
.section .text, "ax" # 0x80003640 - 0x803CB1C0
.global __GBAHandler
__GBAHandler:
/* 803CAC08 003C7B68 7C 08 02 A6 */ mflr r0
/* 803CAC0C 003C7B6C 90 01 00 04 */ stw r0, 4(r1)
/* 803CAC10 003C7B70 94 21 FD 08 */ stwu r1, -0x2f8(r1)
/* 803CAC14 003C7B74 93 E1 02 F4 */ stw r31, 0x2f4(r1)
/* 803CAC18 003C7B78 93 C1 02 F0 */ stw r30, 0x2f0(r1)
/* 803CAC1C 003C7B7C 3B C5 00 00 */ addi r30, r5, 0
/* 803CAC20 003C7B80 93 A1 02 EC */ stw r29, 0x2ec(r1)
/* 803CAC24 003C7B84 3B A3 00 00 */ addi r29, r3, 0
/* 803CAC28 003C7B88 3C 60 80 57 */ lis r3, __GBA@ha
/* 803CAC2C 003C7B8C 80 0D B1 58 */ lwz r0, __GBAReset@sda21(r13)
/* 803CAC30 003C7B90 57 A6 40 2E */ slwi r6, r29, 8
/* 803CAC34 003C7B94 2C 00 00 00 */ cmpwi r0, 0
/* 803CAC38 003C7B98 38 03 A1 A0 */ addi r0, r3, __GBA@l
/* 803CAC3C 003C7B9C 7F E0 32 14 */ add r31, r0, r6
/* 803CAC40 003C7BA0 40 82 00 88 */ bne lbl_803CACC8
/* 803CAC44 003C7BA4 54 80 07 3F */ clrlwi. r0, r4, 0x1c
/* 803CAC48 003C7BA8 41 82 00 10 */ beq lbl_803CAC58
/* 803CAC4C 003C7BAC 38 00 00 01 */ li r0, 1
/* 803CAC50 003C7BB0 90 1F 00 20 */ stw r0, 0x20(r31)
/* 803CAC54 003C7BB4 48 00 00 0C */ b lbl_803CAC60
lbl_803CAC58:
/* 803CAC58 003C7BB8 38 00 00 00 */ li r0, 0
/* 803CAC5C 003C7BBC 90 1F 00 20 */ stw r0, 0x20(r31)
lbl_803CAC60:
/* 803CAC60 003C7BC0 81 9F 00 38 */ lwz r12, 0x38(r31)
/* 803CAC64 003C7BC4 28 0C 00 00 */ cmplwi r12, 0
/* 803CAC68 003C7BC8 41 82 00 18 */ beq lbl_803CAC80
/* 803CAC6C 003C7BCC 38 00 00 00 */ li r0, 0
/* 803CAC70 003C7BD0 7D 88 03 A6 */ mtlr r12
/* 803CAC74 003C7BD4 90 1F 00 38 */ stw r0, 0x38(r31)
/* 803CAC78 003C7BD8 7F A3 EB 78 */ mr r3, r29
/* 803CAC7C 003C7BDC 4E 80 00 21 */ blrl
lbl_803CAC80:
/* 803CAC80 003C7BE0 80 1F 00 1C */ lwz r0, 0x1c(r31)
/* 803CAC84 003C7BE4 28 00 00 00 */ cmplwi r0, 0
/* 803CAC88 003C7BE8 41 82 00 40 */ beq lbl_803CACC8
/* 803CAC8C 003C7BEC 38 61 00 18 */ addi r3, r1, 0x18
/* 803CAC90 003C7BF0 4B FB 49 85 */ bl OSClearContext
/* 803CAC94 003C7BF4 38 61 00 18 */ addi r3, r1, 0x18
/* 803CAC98 003C7BF8 4B FB 47 85 */ bl OSSetCurrentContext
/* 803CAC9C 003C7BFC 81 9F 00 1C */ lwz r12, 0x1c(r31)
/* 803CACA0 003C7C00 38 00 00 00 */ li r0, 0
/* 803CACA4 003C7C04 38 7D 00 00 */ addi r3, r29, 0
/* 803CACA8 003C7C08 90 1F 00 1C */ stw r0, 0x1c(r31)
/* 803CACAC 003C7C0C 7D 88 03 A6 */ mtlr r12
/* 803CACB0 003C7C10 80 9F 00 20 */ lwz r4, 0x20(r31)
/* 803CACB4 003C7C14 4E 80 00 21 */ blrl
/* 803CACB8 003C7C18 38 61 00 18 */ addi r3, r1, 0x18
/* 803CACBC 003C7C1C 4B FB 49 59 */ bl OSClearContext
/* 803CACC0 003C7C20 7F C3 F3 78 */ mr r3, r30
/* 803CACC4 003C7C24 4B FB 47 59 */ bl OSSetCurrentContext
lbl_803CACC8:
/* 803CACC8 003C7C28 80 01 02 FC */ lwz r0, 0x2fc(r1)
/* 803CACCC 003C7C2C 83 E1 02 F4 */ lwz r31, 0x2f4(r1)
/* 803CACD0 003C7C30 83 C1 02 F0 */ lwz r30, 0x2f0(r1)
/* 803CACD4 003C7C34 83 A1 02 EC */ lwz r29, 0x2ec(r1)
/* 803CACD8 003C7C38 38 21 02 F8 */ addi r1, r1, 0x2f8
/* 803CACDC 003C7C3C 7C 08 03 A6 */ mtlr r0
/* 803CACE0 003C7C40 4E 80 00 20 */ blr
.global __GBASyncCallback
__GBASyncCallback:
/* 803CACE4 003C7C44 7C 08 02 A6 */ mflr r0
/* 803CACE8 003C7C48 3C 80 80 57 */ lis r4, __GBA@ha
/* 803CACEC 003C7C4C 90 01 00 04 */ stw r0, 4(r1)
/* 803CACF0 003C7C50 54 63 40 2E */ slwi r3, r3, 8
/* 803CACF4 003C7C54 38 04 A1 A0 */ addi r0, r4, __GBA@l
/* 803CACF8 003C7C58 7C 60 1A 14 */ add r3, r0, r3
/* 803CACFC 003C7C5C 94 21 FF F8 */ stwu r1, -8(r1)
/* 803CAD00 003C7C60 38 63 00 24 */ addi r3, r3, 0x24
/* 803CAD04 003C7C64 4B FB A4 F5 */ bl OSWakeupThread
/* 803CAD08 003C7C68 80 01 00 0C */ lwz r0, 0xc(r1)
/* 803CAD0C 003C7C6C 38 21 00 08 */ addi r1, r1, 8
/* 803CAD10 003C7C70 7C 08 03 A6 */ mtlr r0
/* 803CAD14 003C7C74 4E 80 00 20 */ blr
.global __GBASync
__GBASync:
/* 803CAD18 003C7C78 7C 08 02 A6 */ mflr r0
/* 803CAD1C 003C7C7C 3C 80 80 57 */ lis r4, __GBA@ha
/* 803CAD20 003C7C80 90 01 00 04 */ stw r0, 4(r1)
/* 803CAD24 003C7C84 54 63 40 2E */ slwi r3, r3, 8
/* 803CAD28 003C7C88 38 04 A1 A0 */ addi r0, r4, __GBA@l
/* 803CAD2C 003C7C8C 94 21 FF E8 */ stwu r1, -0x18(r1)
/* 803CAD30 003C7C90 93 E1 00 14 */ stw r31, 0x14(r1)
/* 803CAD34 003C7C94 7F E0 1A 14 */ add r31, r0, r3
/* 803CAD38 003C7C98 93 C1 00 10 */ stw r30, 0x10(r1)
/* 803CAD3C 003C7C9C 4B FB 69 25 */ bl OSDisableInterrupts
/* 803CAD40 003C7CA0 7C 7E 1B 78 */ mr r30, r3
/* 803CAD44 003C7CA4 48 00 00 0C */ b lbl_803CAD50
lbl_803CAD48:
/* 803CAD48 003C7CA8 38 7F 00 24 */ addi r3, r31, 0x24
/* 803CAD4C 003C7CAC 4B FB A3 C1 */ bl OSSleepThread
lbl_803CAD50:
/* 803CAD50 003C7CB0 80 1F 00 1C */ lwz r0, 0x1c(r31)
/* 803CAD54 003C7CB4 28 00 00 00 */ cmplwi r0, 0
/* 803CAD58 003C7CB8 40 82 FF F0 */ bne lbl_803CAD48
/* 803CAD5C 003C7CBC 83 FF 00 20 */ lwz r31, 0x20(r31)
/* 803CAD60 003C7CC0 7F C3 F3 78 */ mr r3, r30
/* 803CAD64 003C7CC4 4B FB 69 25 */ bl OSRestoreInterrupts
/* 803CAD68 003C7CC8 7F E3 FB 78 */ mr r3, r31
/* 803CAD6C 003C7CCC 80 01 00 1C */ lwz r0, 0x1c(r1)
/* 803CAD70 003C7CD0 83 E1 00 14 */ lwz r31, 0x14(r1)
/* 803CAD74 003C7CD4 83 C1 00 10 */ lwz r30, 0x10(r1)
/* 803CAD78 003C7CD8 38 21 00 18 */ addi r1, r1, 0x18
/* 803CAD7C 003C7CDC 7C 08 03 A6 */ mtlr r0
/* 803CAD80 003C7CE0 4E 80 00 20 */ blr
.global TypeAndStatusCallback
TypeAndStatusCallback:
/* 803CAD84 003C7CE4 7C 08 02 A6 */ mflr r0
/* 803CAD88 003C7CE8 90 01 00 04 */ stw r0, 4(r1)
/* 803CAD8C 003C7CEC 94 21 FD 10 */ stwu r1, -0x2f0(r1)
/* 803CAD90 003C7CF0 93 E1 02 EC */ stw r31, 0x2ec(r1)
/* 803CAD94 003C7CF4 3B E3 00 00 */ addi r31, r3, 0
/* 803CAD98 003C7CF8 3C 60 80 57 */ lis r3, __GBA@ha
/* 803CAD9C 003C7CFC 93 C1 02 E8 */ stw r30, 0x2e8(r1)
/* 803CADA0 003C7D00 57 E5 40 2E */ slwi r5, r31, 8
/* 803CADA4 003C7D04 93 A1 02 E4 */ stw r29, 0x2e4(r1)
/* 803CADA8 003C7D08 80 0D B1 58 */ lwz r0, __GBAReset@sda21(r13)
/* 803CADAC 003C7D0C 2C 00 00 00 */ cmpwi r0, 0
/* 803CADB0 003C7D10 38 03 A1 A0 */ addi r0, r3, __GBA@l
/* 803CADB4 003C7D14 7F C0 2A 14 */ add r30, r0, r5
/* 803CADB8 003C7D18 40 82 00 D4 */ bne lbl_803CAE8C
/* 803CADBC 003C7D1C 54 80 06 3F */ clrlwi. r0, r4, 0x18
/* 803CADC0 003C7D20 40 82 00 14 */ bne lbl_803CADD4
/* 803CADC4 003C7D24 54 83 00 1E */ rlwinm r3, r4, 0, 0, 0xf
/* 803CADC8 003C7D28 3C 03 FF FC */ addis r0, r3, 0xfffc
/* 803CADCC 003C7D2C 28 00 00 00 */ cmplwi r0, 0
/* 803CADD0 003C7D30 41 82 00 10 */ beq lbl_803CADE0
lbl_803CADD4:
/* 803CADD4 003C7D34 38 00 00 01 */ li r0, 1
/* 803CADD8 003C7D38 90 1E 00 20 */ stw r0, 0x20(r30)
/* 803CADDC 003C7D3C 48 00 00 3C */ b lbl_803CAE18
lbl_803CADE0:
/* 803CADE0 003C7D40 3C 60 80 3D */ lis r3, __GBAHandler@ha
/* 803CADE4 003C7D44 80 BE 00 0C */ lwz r5, 0xc(r30)
/* 803CADE8 003C7D48 39 03 AC 08 */ addi r8, r3, __GBAHandler@l
/* 803CADEC 003C7D4C 80 FE 00 10 */ lwz r7, 0x10(r30)
/* 803CADF0 003C7D50 81 3E 00 30 */ lwz r9, 0x30(r30)
/* 803CADF4 003C7D54 7F E3 FB 78 */ mr r3, r31
/* 803CADF8 003C7D58 81 5E 00 34 */ lwz r10, 0x34(r30)
/* 803CADFC 003C7D5C 38 9E 00 00 */ addi r4, r30, 0
/* 803CAE00 003C7D60 38 DE 00 05 */ addi r6, r30, 5
/* 803CAE04 003C7D64 4B FF 48 95 */ bl SITransfer
/* 803CAE08 003C7D68 2C 03 00 00 */ cmpwi r3, 0
/* 803CAE0C 003C7D6C 40 82 00 80 */ bne lbl_803CAE8C
/* 803CAE10 003C7D70 38 00 00 02 */ li r0, 2
/* 803CAE14 003C7D74 90 1E 00 20 */ stw r0, 0x20(r30)
lbl_803CAE18:
/* 803CAE18 003C7D78 81 9E 00 38 */ lwz r12, 0x38(r30)
/* 803CAE1C 003C7D7C 28 0C 00 00 */ cmplwi r12, 0
/* 803CAE20 003C7D80 41 82 00 18 */ beq lbl_803CAE38
/* 803CAE24 003C7D84 38 00 00 00 */ li r0, 0
/* 803CAE28 003C7D88 7D 88 03 A6 */ mtlr r12
/* 803CAE2C 003C7D8C 90 1E 00 38 */ stw r0, 0x38(r30)
/* 803CAE30 003C7D90 7F E3 FB 78 */ mr r3, r31
/* 803CAE34 003C7D94 4E 80 00 21 */ blrl
lbl_803CAE38:
/* 803CAE38 003C7D98 80 1E 00 1C */ lwz r0, 0x1c(r30)
/* 803CAE3C 003C7D9C 28 00 00 00 */ cmplwi r0, 0
/* 803CAE40 003C7DA0 41 82 00 4C */ beq lbl_803CAE8C
/* 803CAE44 003C7DA4 4B FB 46 35 */ bl OSGetCurrentContext
/* 803CAE48 003C7DA8 3B A3 00 00 */ addi r29, r3, 0
/* 803CAE4C 003C7DAC 38 61 00 10 */ addi r3, r1, 0x10
/* 803CAE50 003C7DB0 4B FB 47 C5 */ bl OSClearContext
/* 803CAE54 003C7DB4 38 61 00 10 */ addi r3, r1, 0x10
/* 803CAE58 003C7DB8 4B FB 45 C5 */ bl OSSetCurrentContext
/* 803CAE5C 003C7DBC 81 9E 00 1C */ lwz r12, 0x1c(r30)
/* 803CAE60 003C7DC0 38 00 00 00 */ li r0, 0
/* 803CAE64 003C7DC4 38 7F 00 00 */ addi r3, r31, 0
/* 803CAE68 003C7DC8 90 1E 00 1C */ stw r0, 0x1c(r30)
/* 803CAE6C 003C7DCC 7D 88 03 A6 */ mtlr r12
/* 803CAE70 003C7DD0 80 9E 00 20 */ lwz r4, 0x20(r30)
/* 803CAE74 003C7DD4 4E 80 00 21 */ blrl
/* 803CAE78 003C7DD8 38 61 00 10 */ addi r3, r1, 0x10
/* 803CAE7C 003C7DDC 4B FB 47 99 */ bl OSClearContext
/* 803CAE80 003C7DE0 7F A3 EB 78 */ mr r3, r29
/* 803CAE84 003C7DE4 4B FB 45 99 */ bl OSSetCurrentContext
/* 803CAE88 003C7DE8 4B FB 9C 65 */ bl __OSReschedule
lbl_803CAE8C:
/* 803CAE8C 003C7DEC 80 01 02 F4 */ lwz r0, 0x2f4(r1)
/* 803CAE90 003C7DF0 83 E1 02 EC */ lwz r31, 0x2ec(r1)
/* 803CAE94 003C7DF4 83 C1 02 E8 */ lwz r30, 0x2e8(r1)
/* 803CAE98 003C7DF8 83 A1 02 E4 */ lwz r29, 0x2e4(r1)
/* 803CAE9C 003C7DFC 38 21 02 F0 */ addi r1, r1, 0x2f0
/* 803CAEA0 003C7E00 7C 08 03 A6 */ mtlr r0
/* 803CAEA4 003C7E04 4E 80 00 20 */ blr
.global __GBATransfer
__GBATransfer:
/* 803CAEA8 003C7E08 7C 08 02 A6 */ mflr r0
/* 803CAEAC 003C7E0C 90 01 00 04 */ stw r0, 4(r1)
/* 803CAEB0 003C7E10 94 21 FF D0 */ stwu r1, -0x30(r1)
/* 803CAEB4 003C7E14 BF 61 00 1C */ stmw r27, 0x1c(r1)
/* 803CAEB8 003C7E18 3B 63 00 00 */ addi r27, r3, 0
/* 803CAEBC 003C7E1C 3C 60 80 57 */ lis r3, __GBA@ha
/* 803CAEC0 003C7E20 57 67 40 2E */ slwi r7, r27, 8
/* 803CAEC4 003C7E24 38 03 A1 A0 */ addi r0, r3, __GBA@l
/* 803CAEC8 003C7E28 3B 84 00 00 */ addi r28, r4, 0
/* 803CAECC 003C7E2C 3B A5 00 00 */ addi r29, r5, 0
/* 803CAED0 003C7E30 3B E6 00 00 */ addi r31, r6, 0
/* 803CAED4 003C7E34 7F C0 3A 14 */ add r30, r0, r7
/* 803CAED8 003C7E38 4B FB 67 89 */ bl OSDisableInterrupts
/* 803CAEDC 003C7E3C 93 FE 00 38 */ stw r31, 0x38(r30)
/* 803CAEE0 003C7E40 3C 80 80 3D */ lis r4, TypeAndStatusCallback@ha
/* 803CAEE4 003C7E44 3B E3 00 00 */ addi r31, r3, 0
/* 803CAEE8 003C7E48 93 9E 00 0C */ stw r28, 0xc(r30)
/* 803CAEEC 003C7E4C 38 84 AD 84 */ addi r4, r4, TypeAndStatusCallback@l
/* 803CAEF0 003C7E50 7F 63 DB 78 */ mr r3, r27
/* 803CAEF4 003C7E54 93 BE 00 10 */ stw r29, 0x10(r30)
/* 803CAEF8 003C7E58 4B FF 4D 69 */ bl SIGetTypeAsync
/* 803CAEFC 003C7E5C 7F E3 FB 78 */ mr r3, r31
/* 803CAF00 003C7E60 4B FB 67 89 */ bl OSRestoreInterrupts
/* 803CAF04 003C7E64 BB 61 00 1C */ lmw r27, 0x1c(r1)
/* 803CAF08 003C7E68 38 60 00 00 */ li r3, 0
/* 803CAF0C 003C7E6C 80 01 00 34 */ lwz r0, 0x34(r1)
/* 803CAF10 003C7E70 38 21 00 30 */ addi r1, r1, 0x30
/* 803CAF14 003C7E74 7C 08 03 A6 */ mtlr r0
/* 803CAF18 003C7E78 4E 80 00 20 */ blr