mirror of
https://github.com/thug1src/thug.git
synced 2025-01-22 13:53:46 +00:00
130 lines
3.4 KiB
ArmAsm
130 lines
3.4 KiB
ArmAsm
|
/* SCEI CONFIDENTIAL
|
|||
|
"PlayStation 2" Programmer Tool Runtime Library Release 2.0
|
|||
|
*/
|
|||
|
/*
|
|||
|
* I/O Proseccor sample program
|
|||
|
* Version 1.20
|
|||
|
* Shift-JIS
|
|||
|
*
|
|||
|
* Copyright (C) 1998-1999 Sony Computer Entertainment Inc.
|
|||
|
* All Rights Reserved.
|
|||
|
*
|
|||
|
* ezbgm.irx - bgm_r2s.c
|
|||
|
* raw to spu pcm
|
|||
|
*
|
|||
|
* Version Date Design Log
|
|||
|
* --------------------------------------------------------------------
|
|||
|
* 1.20 Nov.23.1999 morita modify for EzBGM
|
|||
|
* 0.01 Nov.18.1999 ishii optimize for IOP
|
|||
|
*/
|
|||
|
|
|||
|
#include <cpureg.h>
|
|||
|
|
|||
|
#define src a0
|
|||
|
#define dst a1
|
|||
|
#define blk a2
|
|||
|
#define cnt a3
|
|||
|
|
|||
|
.globl _BgmRaw2Spu
|
|||
|
.ent _BgmRaw2Spu
|
|||
|
_BgmRaw2Spu:
|
|||
|
subu sp, (8*4)
|
|||
|
sw s0, 0*4(sp) ; sw s1, 1*4(sp)
|
|||
|
sw s2, 2*4(sp) ; sw s3, 3*4(sp)
|
|||
|
sw s4, 4*4(sp) ; sw s5, 5*4(sp)
|
|||
|
sw s6, 6*4(sp) ; sw s7, 7*4(sp)
|
|||
|
move v0, zero
|
|||
|
move v1, zero
|
|||
|
addi cnt,zero, 256
|
|||
|
|
|||
|
.set noreorder
|
|||
|
/* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>A<EFBFBD><41><EFBFBD>Ŗ<EFBFBD><C596>߂̂Ȃ<CC82><C882>т𐧌<D182><F090A78C>B */
|
|||
|
pcm_separate_loop:
|
|||
|
lw t0, 0*4(src) /* 1 + 4 clock */
|
|||
|
lw t1, 1*4(src) /* 1 + 2 clock */
|
|||
|
|
|||
|
/* 7 clock */
|
|||
|
and s0, t0, 0xffff /* t0 <EFBFBD>̉<EFBFBD><EFBFBD>ʂ<EFBFBD> s0 <EFBFBD><EFBFBD> */
|
|||
|
srl s1, t0, 16 /* t0 <EFBFBD>̏<EFBFBD><EFBFBD>ʂ<EFBFBD> s1 <EFBFBD><EFBFBD> */
|
|||
|
sll t0, t1, 16 /* t1 <EFBFBD>̉<EFBFBD><EFBFBD>ʂ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɃV<EFBFBD>t<EFBFBD>g<EFBFBD><EFBFBD> s0 <EFBFBD><EFBFBD> */
|
|||
|
or s0, t0
|
|||
|
srl t1, t1, 16 /* t1 <EFBFBD>̏<EFBFBD><EFBFBD>ʂ<EFBFBD><EFBFBD>}<EFBFBD>X<EFBFBD>N<EFBFBD><EFBFBD><EFBFBD><EFBFBD> s1 <EFBFBD><EFBFBD> */
|
|||
|
sll t1, t1, 16
|
|||
|
or s1, t1
|
|||
|
|
|||
|
/* <20><><EFBFBD>ɃL<C983><4C><EFBFBD>b<EFBFBD>V<EFBFBD><56><EFBFBD>ɓǂݍ<C782><DD8D>܂<EFBFBD><DC82>Ă<EFBFBD><C482><EFBFBD><EFBFBD>͂<EFBFBD> */
|
|||
|
lw t2, 2*4(src) /* 1 clock */
|
|||
|
lw t3, 3*4(src) /* 1 clock */
|
|||
|
/* <20><><EFBFBD>̃L<CC83><4C><EFBFBD>b<EFBFBD>V<EFBFBD><56><EFBFBD><EFBFBD><EFBFBD>C<EFBFBD><43><EFBFBD><EFBFBD><EFBFBD>ǂݍ<C782><DD8D>ނ<EFBFBD><DE82><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
lw t4, 4*4(src) /* 1 + 4 clock */
|
|||
|
|
|||
|
/* 7 clock */
|
|||
|
and s2, t2, 0xffff /* t2 <EFBFBD>̉<EFBFBD><EFBFBD>ʂ<EFBFBD> s2 <EFBFBD><EFBFBD> */
|
|||
|
srl s3, t2, 16 /* t2 <EFBFBD>̏<EFBFBD><EFBFBD>ʂ<EFBFBD> s3 <EFBFBD><EFBFBD> */
|
|||
|
sll t2, t3, 16 /* t3 <EFBFBD>̉<EFBFBD><EFBFBD>ʂ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɃV<EFBFBD>t<EFBFBD>g<EFBFBD><EFBFBD> s2 <EFBFBD><EFBFBD> */
|
|||
|
or s2, t2
|
|||
|
srl t3, t3, 16 /* t3 <EFBFBD>̏<EFBFBD><EFBFBD>ʂ<EFBFBD><EFBFBD>}<EFBFBD>X<EFBFBD>N<EFBFBD><EFBFBD><EFBFBD><EFBFBD> s3 <EFBFBD><EFBFBD> */
|
|||
|
sll t3, t3, 16
|
|||
|
or s3, t3
|
|||
|
|
|||
|
/* <20><><EFBFBD>ɃL<C983><4C><EFBFBD>b<EFBFBD>V<EFBFBD><56><EFBFBD>ɓǂݍ<C782><DD8D>܂<EFBFBD><DC82>Ă<EFBFBD><C482><EFBFBD><EFBFBD>͂<EFBFBD> */
|
|||
|
lw t5, 5*4(src) /* 1 clock */
|
|||
|
lw t6, 6*4(src) /* 1 clock */
|
|||
|
lw t7, 7*4(src) /* 1 clock */
|
|||
|
add src, 8*4 /* 1 clock */
|
|||
|
|
|||
|
/* 7 clock */
|
|||
|
and s4, t4, 0xffff /* t4 <EFBFBD>̉<EFBFBD><EFBFBD>ʂ<EFBFBD> s4 <EFBFBD><EFBFBD> */
|
|||
|
srl s5, t4, 16 /* t4 <EFBFBD>̏<EFBFBD><EFBFBD>ʂ<EFBFBD> s5 <EFBFBD><EFBFBD> */
|
|||
|
sll t4, t5, 16 /* t5 <EFBFBD>̉<EFBFBD><EFBFBD>ʂ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɃV<EFBFBD>t<EFBFBD>g<EFBFBD><EFBFBD> s4 <EFBFBD><EFBFBD> */
|
|||
|
or s4, t4
|
|||
|
srl t5, t5, 16 /* t5 <EFBFBD>̏<EFBFBD><EFBFBD>ʂ<EFBFBD><EFBFBD>}<EFBFBD>X<EFBFBD>N<EFBFBD><EFBFBD><EFBFBD><EFBFBD> s5 <EFBFBD><EFBFBD> */
|
|||
|
sll t5, t5, 16
|
|||
|
or s5, t5
|
|||
|
|
|||
|
/* store dst1(s0, s2), dst2(s1, s3) */
|
|||
|
/* 4 clock */
|
|||
|
|
|||
|
sw s0, 0*4(dst) ; sw s2, 1*4(dst)
|
|||
|
sw s1, (0*4+512)(dst); sw s3, (1*4+512)(dst)
|
|||
|
/* <20>ȉ<EFBFBD><C889>ƕ<EFBFBD><C695>s<EFBFBD><73><EFBFBD><EFBFBD> +2, 4+2 clock <20>ŏ<EFBFBD><C58F><EFBFBD><EFBFBD><EFBFBD><EFBFBD>܂<EFBFBD><DC82><EFBFBD><EFBFBD>͂<EFBFBD> */
|
|||
|
|
|||
|
/* 7 clock */
|
|||
|
and s6, t6, 0xffff /* t6 <EFBFBD>̉<EFBFBD><EFBFBD>ʂ<EFBFBD> s6 <EFBFBD><EFBFBD> */
|
|||
|
srl s7, t6, 16 /* t6 <EFBFBD>̏<EFBFBD><EFBFBD>ʂ<EFBFBD> s7 <EFBFBD><EFBFBD> */
|
|||
|
sll t6, t7, 16 /* t7 <EFBFBD>̉<EFBFBD><EFBFBD>ʂ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɃV<EFBFBD>t<EFBFBD>g<EFBFBD><EFBFBD> s6 <EFBFBD><EFBFBD> */
|
|||
|
or s6, t6
|
|||
|
srl t7, t7, 16 /* t7 <EFBFBD>̏<EFBFBD><EFBFBD>ʂ<EFBFBD><EFBFBD>}<EFBFBD>X<EFBFBD>N<EFBFBD><EFBFBD><EFBFBD><EFBFBD> s7 <EFBFBD><EFBFBD> */
|
|||
|
sll t7, t7, 16
|
|||
|
or s7, t7
|
|||
|
|
|||
|
/* store dst1(s4, s6), dst2(s5, s7) */
|
|||
|
/* 4 clock */
|
|||
|
sw s4, 2*4(dst) ; sw s6, 3*4(dst)
|
|||
|
sw s5, (2*4+512)(dst) ; sw s7, (3*4+512)(dst)
|
|||
|
/* <20>ȉ<EFBFBD><C889>ƕ<EFBFBD><C695>s<EFBFBD><73><EFBFBD><EFBFBD> +2, 4+2 clock <20>ŏ<EFBFBD><C58F><EFBFBD><EFBFBD><EFBFBD><EFBFBD>܂<EFBFBD><DC82><EFBFBD><EFBFBD>͂<EFBFBD> */
|
|||
|
|
|||
|
add dst, 4*4 /* 1 clock */
|
|||
|
|
|||
|
|
|||
|
/* <20><><EFBFBD><EFBFBD><EFBFBD>܂ŁA<C581><41><EFBFBD>Ŗ<EFBFBD><C596>߂̂Ȃ<CC82><C882>т𐧌<D182><F090A78C>B */
|
|||
|
.set reorder
|
|||
|
|
|||
|
add v0, 8 /* 1 clock */
|
|||
|
blt v0, cnt, pcm_separate_loop /* 1 clock */
|
|||
|
|
|||
|
add dst, 512
|
|||
|
move v0, zero
|
|||
|
|
|||
|
add v1, 1
|
|||
|
blt v1, blk, pcm_separate_loop
|
|||
|
|
|||
|
lw s0, 0*4(sp) ; lw s1, 1*4(sp)
|
|||
|
lw s2, 2*4(sp) ; lw s3, 3*4(sp)
|
|||
|
lw s4, 4*4(sp) ; lw s5, 5*4(sp)
|
|||
|
lw s6, 6*4(sp) ; lw s7, 7*4(sp)
|
|||
|
addu sp, (8*4)
|
|||
|
j ra
|
|||
|
.end _BgmRaw2Spu
|
|||
|
|