X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=Pico%2Fsound%2Fmix.s;h=d44e2280ef4d19fe327af332aafd5345395359b7;hb=dca310c413517d278898b967cfe610574310acd8;hp=bc350270c3912f783c9cc637683a242368acdc84;hpb=cea6590346640236914eeff840401c55db8a77ce;p=picodrive.git diff --git a/Pico/sound/mix.s b/Pico/sound/mix.s index bc35027..d44e228 100644 --- a/Pico/sound/mix.s +++ b/Pico/sound/mix.s @@ -1,5 +1,11 @@ @ vim:filetype=armasm +@ Generic routines for mixing audio samples +@ (c) Copyright 2007, Grazvydas "notaz" Ignotas + + +.text +.align 4 @ this assumes src is word aligned .global mix_16h_to_32 @ int *dest, short *src, int count @@ -290,3 +296,72 @@ m32_16_mo_no_unal2: ldmfd sp!, {r4-r8,lr} bx lr + + +.data +.align 4 + +.global mix_32_to_16l_level +mix_32_to_16l_level: + .word 0 + +.text +.align 4 + +@ same as mix_32_to_16l_stereo, but with additional shift +.global mix_32_to_16l_stereo_lvl @ short *dest, int *src, int count + +mix_32_to_16l_stereo_lvl: + stmfd sp!, {r4-r9,lr} + + ldr r9, =mix_32_to_16l_level + mov lr, #1 + ldr r9, [r9] + + mov r2, r2, lsl #1 + subs r2, r2, #4 + bmi m32_16l_st_l_end + +m32_16l_st_l_loop: + ldmia r0, {r8,r12} + ldmia r1!, {r4-r7} + mov r8, r8, lsl #16 + mov r12,r12,lsl #16 + add r4, r4, r8, asr #16 + add r5, r5, r8, asr #16 + add r6, r6, r12,asr #16 + add r7, r7, r12,asr #16 + mov r4, r4, asr r9 + mov r5, r5, asr r9 + mov r6, r6, asr r9 + mov r7, r7, asr r9 + Limitsh r4 + Limitsh r5 + Limitsh r6 + Limitsh r7 + subs r2, r2, #4 + orr r4, r5, r4, lsr #16 + orr r5, r7, r6, lsr #16 + stmia r0!, {r4,r5} + bpl m32_16l_st_l_loop + +m32_16l_st_l_end: + @ check for remaining bytes to convert + tst r2, #2 + beq m32_16l_st_l_no_unal2 + ldrsh r6, [r0] + ldmia r1!,{r4,r5} + add r4, r4, r6 + add r5, r5, r6 + mov r4, r4, asr r9 + mov r5, r5, asr r9 + Limitsh r4 + Limitsh r5 + orr r4, r5, r4, lsr #16 + str r4, [r0], #4 + +m32_16l_st_l_no_unal2: + ldmfd sp!, {r4-r9,lr} + bx lr + +