SPU data transfer controller
Jump to navigation
Jump to search
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 (to) 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 - SpuWrite 00010034: 800185c8 - SpuRead 00010038: 800185f4 - transfer CD input & voice data to main ram 0001003c: 80018608 - transfer only CD input to main ram 00010040: 80018634 - return
case 0: SpuWrite
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 'force' multiple of 48. this seems erroneous, since multiples other than 64 damage SPU data 000185b0: 3c018003 lui r1,0x8003 though having said that, the other case 'forces' a multiple of 64, so maybe this was just overlooked. 000185b4: a4222a54 sh r2,0x2a54(r1) 000185b8: 0c006bd9 jal 0x0001af64 SpuWrite 000185bc: 02602821 addu r5,r19,r0 size of data to transfer 000185c0: 0800618d j 0x00018634 000185c4: 00000000 nop
case 1: SpuRead
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 'force' multiple of 64 (avoid damaging SPU. not sure it actually does this, since. uh, this, isn't how you force multiples...) 000185dc: 3c018003 lui r1,0x8003 000185e0: a4222a54 sh r2,0x2a54(r1) 000185e4: 0c006776 jal 0x00019dd8 SpuRead 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