SPU data transfer controller

From Final Fantasy Hacktics Wiki
(Redirected from Transfer Data to SPU)
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