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

	.section .bss

	.global NNS_G3dGeBuffer
NNS_G3dGeBuffer: ; 0x021D1C80
	.space 0x4

	.global NNS_G3dFlagGXDmaAsync
NNS_G3dFlagGXDmaAsync: ; 0x021D1C84
	.space 0x4

	.global NNS_G3dFlagUseFastDma
NNS_G3dFlagUseFastDma: ; 0x021D1C88
	.space 0x4

	.section .text

	arm_func_start NNS_G3dGeBufferOP_N
NNS_G3dGeBufferOP_N: ; 0x020BB1C0
	stmdb sp!, {r4-r6,lr}
	ldr r3, _020BB2A4 ; =NNS_G3dGeBuffer
	mov r6, r0
	ldr r12, [r3, #0x0]
	mov r5, r1
	mov r4, r2
	cmp r12, #0x0
	beq _020BB278
	ldr r0, _020BB2A8 ; =NNS_G3dFlagGXDmaAsync
	ldr r0, [r0, #0x0]
	cmp r0, #0x0
	beq _020BB24C
	ldr r2, [r12, #0x0]
	add r0, r2, #0x1
	add r1, r0, r4
	cmp r1, #0xc0
	bhi _020BB24C
	str r0, [r12, #0x0]
	ldr r0, [r3, #0x0]
	cmp r4, #0x0
	add r0, r0, r2, lsl #0x2
	str r6, [r0, #0x4]
	ldmeqia sp!, {r4-r6,pc}
	ldr r2, [r3, #0x0]
	mov r0, r5
	ldr r1, [r2], #0x4
	add r1, r2, r1, lsl #0x2
	mov r2, r4, lsl #0x2
	bl MIi_CpuCopyFast
	ldr r0, _020BB2A4 ; =NNS_G3dGeBuffer
	ldr r1, [r0, #0x0]
	ldr r0, [r1, #0x0]
	add r0, r0, r4
	str r0, [r1, #0x0]
	ldmia sp!, {r4-r6,pc}
_020BB24C:
	ldr r0, [r12, #0x0]
	cmp r0, #0x0
	beq _020BB260
	bl NNS_G3dGeFlushBuffer
	b _020BB28C
_020BB260:
	ldr r0, _020BB2A8 ; =NNS_G3dFlagGXDmaAsync
	ldr r0, [r0, #0x0]
	cmp r0, #0x0
	beq _020BB28C
	bl NNS_G3dGeWaitSendDL
	b _020BB28C
_020BB278:
	ldr r0, _020BB2A8 ; =NNS_G3dFlagGXDmaAsync
	ldr r0, [r0, #0x0]
	cmp r0, #0x0
	beq _020BB28C
	bl NNS_G3dGeWaitSendDL
_020BB28C:
	ldr r1, _020BB2AC ; =0x04000400
	mov r0, r5
	mov r2, r4, lsl #0x2
	str r6, [r1, #0x0]
	bl MIi_CpuSend32
	ldmia sp!, {r4-r6,pc}
	.balign 4
_020BB2A4: .word NNS_G3dGeBuffer
_020BB2A8: .word NNS_G3dFlagGXDmaAsync
_020BB2AC: .word 0x04000400
	arm_func_end NNS_G3dGeBufferOP_N

	arm_func_start NNS_G3dGeSendDL
NNS_G3dGeSendDL: ; 0x020BB2B0
	stmdb sp!, {r4-r5,lr}
	sub sp, sp, #0x4
	mov r4, r1
	mov r5, r0
	cmp r4, #0x100
	blo _020BB2DC
	ldr r1, _020BB360 ; =GXi_DmaId
	mvn r0, #0x0
	ldr r1, [r1, #0x0]
	cmp r1, r0
	bne _020BB2F8
_020BB2DC:
	mov r2, r4, lsr #0x2
	ldr r0, [r5, #0x0]
	add r1, r5, #0x4
	sub r2, r2, #0x1
	bl NNS_G3dGeBufferOP_N
	add sp, sp, #0x4
	ldmia sp!, {r4-r5,pc}
_020BB2F8:
	bl NNS_G3dGeFlushBuffer
	ldr r0, _020BB364 ; =NNS_G3dFlagUseFastDma
	ldr r1, _020BB368 ; =NNS_G3dFlagGXDmaAsync
	ldr r0, [r0, #0x0]
	mov r2, #0x1
	str r2, [r1, #0x0]
	cmp r0, #0x0
	beq _020BB33C
	ldr r0, _020BB360 ; =GXi_DmaId
	str r1, [sp, #0x0]
	ldr r0, [r0, #0x0]
	ldr r3, _020BB36C ; =simpleUnlock_
	mov r1, r5
	mov r2, r4
	bl MI_SendGXCommandAsyncFast
	add sp, sp, #0x4
	ldmia sp!, {r4-r5,pc}
_020BB33C:
	ldr r0, _020BB360 ; =GXi_DmaId
	str r1, [sp, #0x0]
	ldr r0, [r0, #0x0]
	ldr r3, _020BB36C ; =simpleUnlock_
	mov r1, r5
	mov r2, r4
	bl MI_SendGXCommandAsync
	add sp, sp, #0x4
	ldmia sp!, {r4-r5,pc}
	.balign 4
_020BB360: .word GXi_DmaId
_020BB364: .word NNS_G3dFlagUseFastDma
_020BB368: .word NNS_G3dFlagGXDmaAsync
_020BB36C: .word simpleUnlock_
	arm_func_end NNS_G3dGeSendDL

	arm_func_start simpleUnlock_
simpleUnlock_: ; 0x020BB370
	mov r1, #0x0
	str r1, [r0, #0x0]
	bx lr
	arm_func_end simpleUnlock_

	arm_func_start NNS_G3dGeWaitSendDL
NNS_G3dGeWaitSendDL: ; 0x020BB37C
	ldr r0, _020BB390 ; =NNS_G3dFlagGXDmaAsync
_020BB380:
	ldr r1, [r0, #0x0]
	cmp r1, #0x0
	bne _020BB380
	bx lr
	.balign 4
_020BB390: .word NNS_G3dFlagGXDmaAsync
	arm_func_end NNS_G3dGeWaitSendDL

	arm_func_start NNS_G3dGeFlushBuffer
NNS_G3dGeFlushBuffer: ; 0x020BB394
	stmdb sp!, {lr}
	sub sp, sp, #0x4
	ldr r0, _020BB3FC ; =NNS_G3dFlagGXDmaAsync
	ldr r0, [r0, #0x0]
	cmp r0, #0x0
	beq _020BB3B0
	bl NNS_G3dGeWaitSendDL
_020BB3B0:
	ldr r0, _020BB400 ; =NNS_G3dGeBuffer
	ldr r0, [r0, #0x0]
	cmp r0, #0x0
	addeq sp, sp, #0x4
	ldmeqia sp!, {pc}
	ldr r2, [r0, #0x0]
	cmp r2, #0x0
	addeq sp, sp, #0x4
	ldmeqia sp!, {pc}
	ldr r1, _020BB404 ; =0x04000400
	add r0, r0, #0x4
	mov r2, r2, lsl #0x2
	bl MIi_CpuSend32
	ldr r0, _020BB400 ; =NNS_G3dGeBuffer
	mov r1, #0x0
	ldr r0, [r0, #0x0]
	str r1, [r0, #0x0]
	add sp, sp, #0x4
	ldmia sp!, {pc}
	.balign 4
_020BB3FC: .word NNS_G3dFlagGXDmaAsync
_020BB400: .word NNS_G3dGeBuffer
_020BB404: .word 0x04000400
	arm_func_end NNS_G3dGeFlushBuffer