URL
https://opencores.org/ocsvn/psg16/psg16/trunk
Subversion Repositories psg16
[/] [psg16/] [trunk/] [software/] [code snippets/] [Beep.asm] - Rev 2
Compare with Previous | Blame | View Log
PSG EQU 0xFFFF_FFFF_FFD5_0000PSGFREQ0 EQU 0xFFFF_FFFF_FFD5_0000PSGPW0 EQU 0xFFFF_FFFF_FFD5_0002PSGCTRL0 EQU 0xFFFF_FFFF_FFD5_0004PSGADSR0 EQU 0xFFFF_FFFF_FFD5_0006;--------------------------------------------------------------------------; Sound a 800 Hz beep;--------------------------------------------------------------------------;Beep:subui sp,sp,#16sm [sp],r1/lrori r1,r0,#15 ; master volume to maxsc r1,PSG+128ori r1,r0,#13422 ; 800Hzsc r1,PSGFREQ0; decay (16.384 ms)2; attack (8.192 ms)1; release (1.024 s)A; sustain level Csetlo r1,#0xCA12sc r1,PSGADSR0ori r1,r0,#0x1104 ; gate, output enable, triangle waveformsc r1,PSGCTRL0ori r1,r0,#25000000 ; delay about 1sbeep1:loop r1,beep1ori r1,r0,#0x0104 ; gate off, output enable, triangle waveformsc r1,PSGCTRL0ori r1,r0,#25000000 ; delay about 1sbeep2:loop r1,beep2ori r1,r0,#0x0000 ; gate off, output enable off, no waveformsc r1,PSGCTRL0lm [sp],r1/lrret #16
