Difference between revisions of "SPU data transfer controller"
Jump to navigation
Jump to search
(Created page with "<font face='Courier New'> 00018518: 27bdffd8 addiu r29,r29,0xffd8 0001851c: afb10014 sw r17,0x0014(r29) 00018520: 00808821 addu r17,r4,r0 00018524: afb20018 sw r18,0x0018...") |
m |
||
Line 5: | Line 5: | ||
00018520: 00808821 addu r17,r4,r0 | 00018520: 00808821 addu r17,r4,r0 | ||
00018524: afb20018 sw r18,0x0018(r29) | 00018524: afb20018 sw r18,0x0018(r29) | ||
− | 00018528: 00a09021 addu r18,r5,r0 | + | 00018528: 00a09021 addu r18,r5,r0 spuDecodeData struct (if case 2, 3). sound data to transfer otherwise. |
0001852c: afb3001c sw r19,0x001c(r29) | 0001852c: afb3001c sw r19,0x001c(r29) | ||
00018530: 00c09821 addu r19,r6,r0 | 00018530: 00c09821 addu r19,r6,r0 | ||
00018534: afb00010 sw r16,0x0010(r29) | 00018534: afb00010 sw r16,0x0010(r29) | ||
− | 00018538: 00e08021 addu r16,r7,r0 | + | 00018538: 00e08021 addu r16,r7,r0 p3 = switch case |
0001853c: afbf0020 sw r31,0x0020(r29) | 0001853c: afbf0020 sw r31,0x0020(r29) | ||
− | 00018540: 0c006197 jal 0x0001865c | + | 00018540: 0c006197 jal 0x0001865c [[0001865c - 000186b8]] |
00018544: 34040010 ori r4,r0,0x0010 | 00018544: 34040010 ori r4,r0,0x0010 | ||
00018548: 3c028003 lui r2,0x8003 | 00018548: 3c028003 lui r2,0x8003 | ||
Line 19: | Line 19: | ||
00018558: 3c018003 lui r1,0x8003 | 00018558: 3c018003 lui r1,0x8003 | ||
0001855c: a4222a54 sh r2,0x2a54(r1) | 0001855c: a4222a54 sh r2,0x2a54(r1) | ||
− | 00018560: 0c006c06 jal 0x0001b018 | + | 00018560: 0c006c06 jal 0x0001b018 [[0001b018 - 0001b048|SpuSetTransferMode]] |
00018564: 00002021 addu r4,r0,r0 | 00018564: 00002021 addu r4,r0,r0 | ||
− | 00018568: 0c006bf1 jal 0x0001afc4 | + | 00018568: 0c006bf1 jal 0x0001afc4 [[0001afc4 - 0001b014]] |
0001856c: 02202021 addu r4,r17,r0 | 0001856c: 02202021 addu r4,r17,r0 | ||
00018570: 3210000f andi r16,r16,0x000f | 00018570: 3210000f andi r16,r16,0x000f | ||
00018574: 2610ffff addiu r16,r16,0xffff | 00018574: 2610ffff addiu r16,r16,0xffff | ||
00018578: 2e020005 sltiu r2,r16,0x0005 | 00018578: 2e020005 sltiu r2,r16,0x0005 | ||
− | 0001857c: 1040002d beq r2,r0,0x00018634 | + | 0001857c: 1040002d beq r2,r0,0x00018634 return if illegal case |
00018580: 00101080 sll r2,r16,0x02 | 00018580: 00101080 sll r2,r16,0x02 | ||
00018584: 3c018001 lui r1,0x8001 | 00018584: 3c018001 lui r1,0x8001 | ||
00018588: 00220821 addu r1,r1,r2 | 00018588: 00220821 addu r1,r1,r2 | ||
− | 0001858c: 8c220030 lw r2,0x0030(r1) | + | 0001858c: 8c220030 lw r2,0x0030(r1) switch case |
00018590: 00000000 nop | 00018590: 00000000 nop | ||
00018594: 00400008 jr r2 | 00018594: 00400008 jr r2 | ||
00018598: 00000000 nop | 00018598: 00000000 nop | ||
− | 0001859c: 02402021 addu r4,r18,r0 | + | |
+ | 00010030: 8001859c - finish sound data transfer | ||
+ | 00010034: 800185c8 - start sound data transfer | ||
+ | 00010038: 800185f4 - transfer CD input & voice data to SPU main ram | ||
+ | 0001003c: 80018608 - transfer only CD input to SPU main ram | ||
+ | 00010040: 80018634 - return | ||
+ | |||
+ | case 0: write from DMA to SPU | ||
+ | 0001859c: 02402021 addu r4,r18,r0 address | ||
000185a0: 3c028003 lui r2,0x8003 | 000185a0: 3c028003 lui r2,0x8003 | ||
− | 000185a4: 94422a54 lhu r2,0x2a54(r2) | + | 000185a4: 94422a54 lhu r2,0x2a54(r2) last buffer address |
000185a8: 00000000 nop | 000185a8: 00000000 nop | ||
− | 000185ac: 34420030 ori r2,r2,0x0030 | + | 000185ac: 34420030 ori r2,r2,0x0030 set at least 0x30 buffer address? some kind of rounding? |
000185b0: 3c018003 lui r1,0x8003 | 000185b0: 3c018003 lui r1,0x8003 | ||
000185b4: a4222a54 sh r2,0x2a54(r1) | 000185b4: a4222a54 sh r2,0x2a54(r1) | ||
− | 000185b8: 0c006bd9 jal 0x0001af64 | + | 000185b8: 0c006bd9 jal 0x0001af64 [[Call Finish data transfer to SPU]] |
− | 000185bc: 02602821 addu r5,r19,r0 | + | 000185bc: 02602821 addu r5,r19,r0 size of data to transfer |
000185c0: 0800618d j 0x00018634 | 000185c0: 0800618d j 0x00018634 | ||
000185c4: 00000000 nop | 000185c4: 00000000 nop | ||
+ | |||
+ | case 1: read data from RAM to DMA | ||
000185c8: 02402021 addu r4,r18,r0 | 000185c8: 02402021 addu r4,r18,r0 | ||
000185cc: 3c028003 lui r2,0x8003 | 000185cc: 3c028003 lui r2,0x8003 | ||
− | 000185d0: 94422a54 lhu r2,0x2a54(r2) | + | 000185d0: 94422a54 lhu r2,0x2a54(r2) last buffer address |
000185d4: 00000000 nop | 000185d4: 00000000 nop | ||
− | 000185d8: 34420050 ori r2,r2,0x0050 | + | 000185d8: 34420050 ori r2,r2,0x0050 set at least 0x50 buffer address? |
000185dc: 3c018003 lui r1,0x8003 | 000185dc: 3c018003 lui r1,0x8003 | ||
000185e0: a4222a54 sh r2,0x2a54(r1) | 000185e0: a4222a54 sh r2,0x2a54(r1) | ||
− | 000185e4: 0c006776 jal 0x00019dd8 | + | 000185e4: 0c006776 jal 0x00019dd8 [[Call Begin transfer data to SPU]] |
− | 000185e8: 02602821 addu r5,r19,r0 | + | 000185e8: 02602821 addu r5,r19,r0 size of data to transfer |
000185ec: 0800618d j 0x00018634 | 000185ec: 0800618d j 0x00018634 | ||
000185f0: 00000000 nop | 000185f0: 00000000 nop | ||
− | 000185f4: 02402021 addu r4,r18,r0 | + | |
+ | case 2: transfer all input data | ||
+ | 000185f4: 02402021 addu r4,r18,r0 RAM address of spuDecodedData struct. | ||
000185f8: 3c028003 lui r2,0x8003 | 000185f8: 3c028003 lui r2,0x8003 | ||
− | 000185fc: 94422a54 lhu r2,0x2a54(r2) | + | 000185fc: 94422a54 lhu r2,0x2a54(r2) spu buffer |
00018600: 08006186 j 0x00018618 | 00018600: 08006186 j 0x00018618 | ||
− | 00018604: 00002821 addu r5,r0,r0 | + | 00018604: 00002821 addu r5,r0,r0 set transfer of CD input & voice 1, 3 |
− | 00018608: 02402021 addu r4,r18,r0 | + | |
+ | case 3: transfer only CD input data | ||
+ | 00018608: 02402021 addu r4,r18,r0 RAM address of spuDecodedData struct. | ||
0001860c: 3c028003 lui r2,0x8003 | 0001860c: 3c028003 lui r2,0x8003 | ||
− | 00018610: 94422a54 lhu r2,0x2a54(r2) | + | 00018610: 94422a54 lhu r2,0x2a54(r2) spu buffer |
− | 00018614: 34050005 ori r5,r0,0x0005 | + | 00018614: 34050005 ori r5,r0,0x0005 set transfer of CD input only |
− | 00018618: 34420050 ori r2,r2,0x0050 | + | |
+ | case 2 & 3 | ||
+ | 00018618: 34420050 ori r2,r2,0x0050 set spu buffer | 0x50? | ||
0001861c: 3c018003 lui r1,0x8003 | 0001861c: 3c018003 lui r1,0x8003 | ||
00018620: a4222a54 sh r2,0x2a54(r1) | 00018620: a4222a54 sh r2,0x2a54(r1) | ||
− | 00018624: 0c006b1f jal 0x0001ac7c | + | 00018624: 0c006b1f jal 0x0001ac7c [[0001ac7c - 0001acec|SpuReadDecodedData]] |
00018628: 00000000 nop | 00018628: 00000000 nop | ||
0001862c: 3c018003 lui r1,0x8003 | 0001862c: 3c018003 lui r1,0x8003 | ||
00018630: a4222a40 sh r2,0x2a40(r1) | 00018630: a4222a40 sh r2,0x2a40(r1) | ||
+ | |||
+ | return | ||
00018634: 8fbf0020 lw r31,0x0020(r29) | 00018634: 8fbf0020 lw r31,0x0020(r29) | ||
00018638: 8fb3001c lw r19,0x001c(r29) | 00018638: 8fb3001c lw r19,0x001c(r29) |
Revision as of 06:04, 23 January 2025
00018518: 27bdffd8 addiu r29,r29,0xffd8 0001851c: afb10014 sw r17,0x0014(r29) 00018520: 00808821 addu r17,r4,r0 00018524: afb20018 sw r18,0x0018(r29) 00018528: 00a09021 addu r18,r5,r0 spuDecodeData struct (if case 2, 3). sound data to transfer otherwise. 0001852c: afb3001c sw r19,0x001c(r29) 00018530: 00c09821 addu r19,r6,r0 00018534: afb00010 sw r16,0x0010(r29) 00018538: 00e08021 addu r16,r7,r0 p3 = switch case 0001853c: afbf0020 sw r31,0x0020(r29) 00018540: 0c006197 jal 0x0001865c 0001865c - 000186b8 00018544: 34040010 ori r4,r0,0x0010 00018548: 3c028003 lui r2,0x8003 0001854c: 94422a54 lhu r2,0x2a54(r2) 00018550: 00000000 nop 00018554: 34420010 ori r2,r2,0x0010 00018558: 3c018003 lui r1,0x8003 0001855c: a4222a54 sh r2,0x2a54(r1) 00018560: 0c006c06 jal 0x0001b018 SpuSetTransferMode 00018564: 00002021 addu r4,r0,r0 00018568: 0c006bf1 jal 0x0001afc4 0001afc4 - 0001b014 0001856c: 02202021 addu r4,r17,r0 00018570: 3210000f andi r16,r16,0x000f 00018574: 2610ffff addiu r16,r16,0xffff 00018578: 2e020005 sltiu r2,r16,0x0005 0001857c: 1040002d beq r2,r0,0x00018634 return if illegal case 00018580: 00101080 sll r2,r16,0x02 00018584: 3c018001 lui r1,0x8001 00018588: 00220821 addu r1,r1,r2 0001858c: 8c220030 lw r2,0x0030(r1) switch case 00018590: 00000000 nop 00018594: 00400008 jr r2 00018598: 00000000 nop
00010030: 8001859c - finish sound data transfer 00010034: 800185c8 - start sound data transfer 00010038: 800185f4 - transfer CD input & voice data to SPU main ram 0001003c: 80018608 - transfer only CD input to SPU main ram 00010040: 80018634 - return
case 0: write from DMA to SPU
0001859c: 02402021 addu r4,r18,r0 address 000185a0: 3c028003 lui r2,0x8003 000185a4: 94422a54 lhu r2,0x2a54(r2) last buffer address 000185a8: 00000000 nop 000185ac: 34420030 ori r2,r2,0x0030 set at least 0x30 buffer address? some kind of rounding? 000185b0: 3c018003 lui r1,0x8003 000185b4: a4222a54 sh r2,0x2a54(r1) 000185b8: 0c006bd9 jal 0x0001af64 Call Finish data transfer to SPU 000185bc: 02602821 addu r5,r19,r0 size of data to transfer 000185c0: 0800618d j 0x00018634 000185c4: 00000000 nop
case 1: read data from RAM to DMA
000185c8: 02402021 addu r4,r18,r0 000185cc: 3c028003 lui r2,0x8003 000185d0: 94422a54 lhu r2,0x2a54(r2) last buffer address 000185d4: 00000000 nop 000185d8: 34420050 ori r2,r2,0x0050 set at least 0x50 buffer address? 000185dc: 3c018003 lui r1,0x8003 000185e0: a4222a54 sh r2,0x2a54(r1) 000185e4: 0c006776 jal 0x00019dd8 Call Begin transfer data to SPU 000185e8: 02602821 addu r5,r19,r0 size of data to transfer 000185ec: 0800618d j 0x00018634 000185f0: 00000000 nop
case 2: transfer all input data
000185f4: 02402021 addu r4,r18,r0 RAM address of spuDecodedData struct. 000185f8: 3c028003 lui r2,0x8003 000185fc: 94422a54 lhu r2,0x2a54(r2) spu buffer 00018600: 08006186 j 0x00018618 00018604: 00002821 addu r5,r0,r0 set transfer of CD input & voice 1, 3
case 3: transfer only CD input data
00018608: 02402021 addu r4,r18,r0 RAM address of spuDecodedData struct. 0001860c: 3c028003 lui r2,0x8003 00018610: 94422a54 lhu r2,0x2a54(r2) spu buffer 00018614: 34050005 ori r5,r0,0x0005 set transfer of CD input only
case 2 & 3
00018618: 34420050 ori r2,r2,0x0050 set spu buffer | 0x50? 0001861c: 3c018003 lui r1,0x8003 00018620: a4222a54 sh r2,0x2a54(r1) 00018624: 0c006b1f jal 0x0001ac7c SpuReadDecodedData 00018628: 00000000 nop 0001862c: 3c018003 lui r1,0x8003 00018630: a4222a40 sh r2,0x2a40(r1)
return
00018634: 8fbf0020 lw r31,0x0020(r29) 00018638: 8fb3001c lw r19,0x001c(r29) 0001863c: 8fb20018 lw r18,0x0018(r29) 00018640: 8fb10014 lw r17,0x0014(r29) 00018644: 8fb00010 lw r16,0x0010(r29) 00018648: 27bd0028 addiu r29,r29,0x0028 0001864c: 03e00008 jr r31 00018650: 00000000 nop