Home » Archimedes archive » Zipped Apps » 6502em » !6502Em/src/Sound6
!6502Em/src/Sound6
This website contains an archive of files for the Acorn Electron, BBC Micro, Acorn Archimedes, Commodore 16 and Commodore 64 computers, which Dominic Ford has rescued from his private collection of floppy disks and cassettes.
Some of these files were originally commercial releases in the 1980s and 1990s, but they are now widely available online. I assume that copyright over them is no longer being asserted. If you own the copyright and would like files to be removed, please contact me.
Tape/disk: | Home » Archimedes archive » Zipped Apps » 6502em |
Filename: | !6502Em/src/Sound6 |
Read OK: | ✔ |
File size: | 5697 bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM > Sound5 20REM 30REM BBC Sound and Speech emulation library 40REM For Mike Borcherds BBC emulator 50REM This file by Dominic Symes 60 70REM Set up global defaults 80DEF PROCsound_define 90REM Size of circular buffer for each channel 100sound_buf_size_log%=10 110sound_buf_size%=(1<<sound_buf_size_log%) 120ENDPROC 130 140REM Call to set up sound tables 150DEF PROCsound_init 160LOCAL a,f% 170PROCsound_define 180REMvolume%=127 190DIM sound_buffer% (4*sound_buf_size%) 200DIM sound_vol_table% &40 210DIM sound_sample% &200 220DIM sound_stack% &80 230FOR f%=0 TO &3FF 240?(sound_buffer%+f%)=f%*10 250NEXT 260SYS "Sound_Volume",127 TO sc_vol 270REM Set up sound sample for pitch channels - half way between 280REM a sine wave and square wave gives best likeness. 290FOR f%=0 TO &7F 300SYS "6502_Sound",f%,A% 310a=SIN((f%/128)*PI) 320IF a<>0 THEN a=a^.2 330SYS "Sound_SoundLog",&7FFFFFFF*a TO a 340?(sound_sample%+f%)=a 350?(sound_sample%+&80+f%)=a+1 360NEXT 370REM Set up the sound sample for the pulse generator 380FOR f%=0 TO &3F 390?(sound_sample%+&100+f%)=?(sound_sample%+f%*(8/4)) 400NEXT 410FOR f%=0 TO &BF 420?(sound_sample%+&110+f%)=?(sound_sample%+&80+f%*(8/12)) 430NEXT 440SYS "Sound_Volume",sc_vol 450sound_voice%=code+!(code+22*4) 460!(sound_voice%+0)=sound_buffer% 470!(sound_voice%+4)=sound_vol_table% 480!(sound_voice%+8)=sound_sample% 490!(sound_voice%+12)=sound_stack%+&40 500sound_voice%+=16 510ENDPROC 520 530DEFPROCsound_reinit 540sound_voice%=code+!(code+22*4) 550!(sound_voice%+0)=sound_buffer% 560!(sound_voice%+4)=sound_vol_table% 570!(sound_voice%+8)=sound_sample% 580!(sound_voice%+12)=sound_stack%+&40 590sound_voice%+=16 600ENDPROC 610 620REM Call just before starting the emulator 630DEF PROCsound_setup 640LOCAL f%,a% 650SYS "Sound_InstallVoice",sound_voice%,0 TO ,sound_voice_slot% 660SYS "Sound_Configure",4,208,48,0,0 TO sc_0,sc_1,sc_2,sc_3,sc_4 670SYS "Sound_AttachVoice",1,1 TO ,sv_1 680SYS "Sound_AttachVoice",2,1 TO ,sv_2 690SYS "Sound_AttachVoice",3,1 TO ,sv_3 700SYS "Sound_AttachVoice",4,1 TO ,sv_4 710SYS "Sound_AttachNamedVoice",1,"6502Emulator" 720SYS "Sound_AttachNamedVoice",2,"6502Emulator" 730SYS "Sound_AttachNamedVoice",3,"6502Emulator" 740SYS "Sound_AttachNamedVoice",4,"6502Emulator" 750REM Start infinite duration notes on each of the channels 760SYS "Sound_Volume",volume% TO sc_vol 770REM Set up the linear to log volume conversion 780FOR f%=0 TO &F 790a%=f%+(f%<<4) 800a%=a%+(a%<<8) 810a%=a%+(a%<<16) 820SYS "Sound_SoundLog",(a%>>>1) TO a% 830REMPRINT a% 840?(sound_vol_table%+f%)=a% 850NEXT 860SOUND 1,-1,1,255 870SOUND 2,-1,1,255 880SOUND 3,-1,1,255 890SOUND 4,-1,1,255 900ENDPROC 910 920REM Call after exiting the emulator 930DEF PROCsound_restore 940SYS "Sound_Volume",sc_vol 950SYS "Sound_Configure",sc_0,sc_1,sc_2,sc_3,sc_4 960SYS "Sound_AttachVoice",1,sv_1 970SYS "Sound_AttachVoice",2,sv_2 980SYS "Sound_AttachVoice",3,sv_3 990SYS "Sound_AttachVoice",4,sv_4 1000SYS "Sound_RemoveVoice",0,sound_voice_slot% 1010ENDPROC 1020 1030REM Code to interpret writes to the sound chip 1040REM mem=3 A=4 X=5 Y=6 F=7 SP=8 time=9 zpc=10 table=11 1050REM p=pass 1060DEF FNsound_latch 1070PROCsound_define 1080[OPT p 1090 1100; the following byte should be written by regb_4f and should 1110; hold a copy of what's on the slow data bus 1120 1130.sound_data EQUD 0 1140 1150; Notes: 1160; Clock is 2Mhz. One buffer fill every 48 micro secs = 96 cycles. 1170; Pitch phase increment = &60000 / (10 bit BBC sound chip freq) 1180; Cleary greatest sensible pitch increment is &4000, so very 1190; small BBC frequencies are conventionally meaningless. 1200; A BBC frequency of 1 is assumed to be an 1210; attempt to modulate the amplitude manually (eg Superior 1220; Software speech) and is handled accordingly. 1230 1240;E Called when latch writes to sound generator 1250; sound_data contains a copy of the byte written to the slow 1260; data bus 1270; R0=value written to latch (b0-b2=0) 1280; R3=BBC memory address (mem) 1290; R9=time in cycles until next clock interrupt 1300;X R0-R2,R13 corrupted 1310; Exits via MOV PC,R14 1320 1330.sound_latch 1340STR mem,memstore 1350TST R0,#1<<3 1360MOVNE PC,R14 ; active low 1370LDR R13,(sound_buffs_addr+12) 1380STMFD R13!,{R3,R14} 1390LDRB R0,sound_data ; get the byte written 1400TST R0,#1<<7 1410BEQ sound_update ; update the frequency 1420MOV R1,R0,LSR#5 1430AND R1,R1,#3 ; channel number (0=tone3 3=noise) 1440TST R0,#1<<4 1450AND R0,R0,#&0F ; data is in b0-b3 1460BNE sound_volume ; volume control 1470TEQ R1,#3 ; noise channel? 1480STRNE R1,sound_channel ; if not set current channel 1490ADR R14,sound_freq0 1500LDR R3,[R14,R1,LSL#2] ; get the current frequency 1510BIC R2,R3,#&0F ; clear bottom 4 bits 1520ORR R2,R2,R0 ; new frequency 1530STR R2,[R14,R1,LSL#2] ; new frequency 1540B sound_frequency 1550.sound_update ; update frequency 1560LDR R1,sound_channel ; current channel 1570ADR R14,sound_freq0 1580LDR R3,[R14,R1,LSL#2] ; get the current frequency 1590AND R2,R3,#&0F ; loose the top bits 1600AND R0,R0,#&3F ; b4-b9 of frequency 1610ORR R2,R2,R0,LSL#4 ; add new high order bits 1620STR R2,[R14,R1,LSL#2] ; new frequency 1630B sound_frequency 1640;NB not sure whether you should update sound_channel here? 1650.sound_volume ; R0=volume (15 off-0 max) 1660RSB R0,R0,#15 ; new vol 0=off 15=max now! 1670ADR R14,sound_amp0 1680LDRB R2,[R14,R1] ; old volume 1690TEQ R0,R2 1700;BEQ sound_latch_end ; volume hasn't changed 1710STRB R0,[R14,R1] ; write the new volume 1720TEQ R1,#3 1730BEQ sound_latch_end ; ignore noise channel 1740ADR R14,sound_freq0 1750LDR R0,[R14,R1,LSL#2] ; get frequency setting 1760TEQ R0,#1 1770BLEQ make_sound ; it's speech 1780B sound_latch_end 1790.sound_frequency ; R1=channel R2=new freq (10 bit) 1800TEQ R1,#3 ; R3=old freq (10 bit) 1810BLEQ sound_noisefreq ; Convert R2 to 10 bit format 1820TEQ R2,#1 ; check for speach 1830BEQ sound_speach_start 1840TEQ R3,#1 1850BLEQ sound_speach_stop 1860MOV R0,#&60000 1870STMFD R13!,{R1} ; save channel number 1880MOV R1,R2 ; denomenator 1890BL div_mod ; R0=pitch accumulator inc corr R3 1900LDMFD R13!,{R1} ; restore channel number 1910CMP R0,#0 1920MOVLE R0,#0 1930CMP R0,#&4000 1940MOVGE R0,#&4000 ; R0=new pitch increment 1950ADR R14,sound_pitch0 1960LDR R2,[R14,R1,LSL#2] 1970MOV R2,R2,LSR#16 1980ORR R2,R0,R2,LSL#16 ; install new pitch increment 1990STR R2,[R14,R1,LSL#2] 2000TEQ R1,#2 ; is it pitch channel 1 2010BNE sound_latch_end ; no 2020LDR R0,sound_freq3 ; 3 bit freq setting of noise chan 2030AND R0,R0,#3 2040TEQ R0,#3 ; is it based on channel 1? 2050BNE sound_latch_end ; no 2060;BL sound_debug 2070MOV R1,#3 ; channel 0 2080LDR R2,sound_freq3 ; channel 0 10-bit frequency 2090B sound_frequency ; update frequency for channel 0 2100.sound_latch_end ; EXIT 2110;BL sound_debug ; print up debug data 2120LDMFD R13!,{R3,PC} ; EXIT 2130.sound_speach_start 2140TEQ R3,#1 2150BEQ sound_latch_end ; already started 2160BL sound_get_time 2170ADR R0,sound_time0 2180STR R2,[R0,R1,LSL#2] ; time this channel last updated 2190TEQ R1,#0 2200;BLEQ log_start 2210B sound_latch_end 2220 2230;E Called when speach stops 2240;X Corrupts R0 2250 2260.sound_speach_stop 2270TEQ R1,#0 2280;BEQ log_end 2290MOV PC,R14 2300 2310.memstore 2320EQUD 0 2330 2340;E R9=Emulator time 'till next event 2350;X R2=current time on the sound decrementing 2MHz clock 2360; R0 corrupted 2370 2380.sound_get_time 2390LDR R0,memstore 2400LDR R2,[R0,#min] 2410SUB R2,R2,R9 ; time passed since last event 2420LDR R0,[R0,#sound_timer] 2430SUB R2,R0,R2 ; current time (dec at 2Mhz) 2440MOV PC,R14 2450 2460;E Volume changed (not just been set to the same value!!!) 2470; This channel in speech mode. 2480; R2=the old volume before the change 2490; R1=BBC channel number (0-3) R9=time 2500;X Buffer filled for manual amplitude modulation 2510; R0 corrupted 2520 2530.make_sound 2540STMFD R13!,{R1-R5,R14} 2550; TEQ R1,#0 2560; LDMNEFD R13!,{R1-R5,PC} 2570; LDRB R0,[mem,#&67] 2580; LDRB R14,[mem,#&68] 2590; ADD R0,R0,R14,LSL#8 2600; LDRB R14,[R0,Y,LSR#24] 2610; ADD R0,R0,Y 2620; ADD R0,R0,R14,LSL#16 2630; LDR R0,[mem,#&60] 2640; BL log_word 2650; MOV R0,R2 2660; BL log_word 2670MOV R4,R2,LSL#1 ; amplitude 0-30 2680SUBS R4,R4,#15 ; amplitude -15 to 15 2690MOVPL R0,#0 2700MOVMI R0,#1 ; sign bit 2710RSBMI R4,R4,#0 ; now +ve (1-15) 2720LDR R14,(sound_buffs_addr+4) ; log amp table 2730LDRB R4,[R14,R4] ; VIDC amp 2740EOR R4,R4,R0 ; bung in sign to get sample 2750BL sound_get_time ; R2=current time 2760ADR R14,sound_time0 2770LDR R3,[R14,R1,LSL#2] ; time this channel last updated 2780SUBS R0,R3,R2 ; time passed since last update 2790MOVMI R3,R2 ; clip if gone negative 2800CMP R0,#&C000 ; greater than one buffer fill? 2810ADDGE R3,R2,#&C000 ; clip if so 2820; BL log_word 2830ADR R14,sound_filled0 2840LDR R5,[R14,R1,LSL#2] ; current offset in the buffer 2850.make_sound_1 2860ADR R14,sound_read0 2870LDR R0,[R14,R1,LSL#2] ; amount read to 2880SUBS R0,R5,R0 2890ADDMI R0,R0,#sound_buf_size% ; amount in the buffer 2900CMP R0,#512 2910BGT make_sound_1 ; wait for output to catch up 2920LDR R0,sound_buffs_addr 2930ADD R0,R0,R1,LSL#sound_buf_size_log% ; address of buffer 2940.make_sound_2 2950SUB R3,R3,#96 ; try and do another byte 2960CMP R3,R2 2970BLT make_sound_3 ; can't 2980STRB R4,[R0,R5] ; write out a byte 2990; STMFD R13!,{R0} 3000; MOV R0,R4 3010; BL log_word 3020; LDMFD R13!,{R0} 3030ADD R5,R5,#1 3040CMP R5,#sound_buf_size% 3050MOVGE R5,#0 ; wrap buffer offset 3060B make_sound_2 3070.make_sound_3 3080ADD R3,R3,#96 3090ADR R14,sound_filled0 3100STR R5,[R14,R1,LSL#2] ; new buffer offset 3110ADR R14,sound_time0 3120STR R3,[R14,R1,LSL#2] ; new time last updated 3130LDMFD R13!,{R1-R5,PC} 3140 3150;E R2=noise channel frequency (bbc format) 3160;X R2=noise channel frequnecy (10 bit) 3170; Corrupts R0 3180; Don't need to clip since pitch inc can go up to &60000 3190 3200.sound_noisefreq 3210AND R0,R2,#3 3220TEQ R0,#3 3230BEQ sound_usefreq2 3240AND R0,R2,#7 ; FB NF1 NF0 3250ADR R2,sound_noisetab 3260LDR R2,[R2,R0,LSL#2] 3270MOV PC,R14 3280.sound_usefreq2 3290TST R2,#4 3300LDR R2,sound_freq2 ; use tone generator 1 frequency 3310;MOVEQ R2,R2,LSL#4 ; multiply if pulse channel 3320;MOVNE R2,R2,LSR#2 ; divide if noise channel 3321 3322MOV R2,R2,LSL#4 ; changed 11/96 MRB 3323 3370MOV PC,R14 3380.sound_noisetab 3390EQUD &F1 ; pulse high 3400EQUD &1D5 ; pulse med 3410EQUD &3C6 ; pulse low 3420EQUD 0 3430EQUD &1F ; noise high 3440EQUD &A3 ; noise med 3450EQUD &100 ; noise low 3460EQUD 0 3470 3480.sound_channel EQUD 0 ; current note channel (0-2) 3490.sound_freq0 EQUD 0 ; frequency of channel 3 (10 bit) 3500.sound_freq1 EQUD 0 ; frequency of channel 2 3510.sound_freq2 EQUD 0 ; frequency of channel 1 3520.sound_freq3 EQUD 0 ; frequency of channel 0 X FB NF1,0 3530.sound_amp0 EQUB 0 ; amplitude of channel 3 0-15 3540.sound_amp1 EQUB 0 ; amplitude of channel 2 3550.sound_amp2 EQUB 0 ; amplitude of channel 1 3560.sound_amp3 EQUB 0 ; amplitude of channel 0 3570.sound_read0 EQUD 0 ; offset in buffer of start of 3580.sound_read1 EQUD 0 ; unread data 3590.sound_read2 EQUD 0 ; channels 0-3 3600.sound_read3 EQUD 0 ; 3610.sound_filled0 EQUD 0 ; offset in buf filled to chann 0 3620.sound_filled1 EQUD 0 ; offset in buf filled to chann 1 3630.sound_filled2 EQUD 0 ; offset in buf filled to chann 2 3640.sound_filled3 EQUD 0 ; offset in buf filled to chann 3 3650.sound_pitch0 EQUD 0 ; phase pitch channel 0 3660.sound_pitch1 EQUD 0 ; phase pitch channel 1 3670.sound_pitch2 EQUD 0 ; phase pitch channel 2 3680.sound_pitch3 EQUD 0 ; phase pitch channel 3 3690.sound_time0 EQUD 0 ; last time (R9) channel updated 3700.sound_time1 EQUD 0 ; channel 1 (decrements as time 3710.sound_time2 EQUD 0 ; channel 2 goes on) 3720.sound_time3 EQUD 0 ; channel 3 3730 3740;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 3750; Fill sound buffer ; 3760;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 3770 3780;E R0=number of bytes to fill in buffer 3790; R5=bbc channel number 3800; R14 not usable (in IRQ mode) 3810; Return address on stack 3820 3830.sound_fillto 3840STMFD R13!,{R1-R4,R11-R12} 3850ADDS R3,R0,#0 ; number of bytes to do 3860LDMLEFD R13!,{R1-R4,R11-R12,PC} ; none 3870ADR R4,sound_filled0 3880LDR R1,[R4,R5,LSL#2] ; current offset filled to 3890LDR R11,sound_buffs_addr 3900ADD R11,R11,R5,LSL#sound_buf_size_log% ; address of the buffer 3910ADD R12,R11,#sound_buf_size% ; end of the buffer 3920ADD R11,R11,R1 ; address at which to start filling 3930ADR R4,sound_pitch0 3940LDR R1,[R4,R5,LSL#2] ; get phase pitch inc 3950ADR R4,sound_amp0 3960LDRB R4,[R4,R5] ; get BBC amp for this channel 3970LDR R0,(sound_buffs_addr+4) ; volume scaling table 3980LDRB R4,[R0,R4] ; scale volume to VIDC format 3990RSB R4,R4,#(127<<1) ; attenuation 4000TEQ R5,#3 ; noise channel? 4010BEQ sound_fillto_noise 4020ADR R0,sound_freq0 4030LDR R0,[R0,R5,LSL#2] 4040TEQ R0,#1 4050BEQ sound_fillto_speach 4060LDR R2,(sound_buffs_addr+8) ; standard sample 4070.sound_fillto_loop 4080ADD R1,R1,R1,LSL#16 ; advance waveform 4090LDRB R0,[R2,R1,LSR#24] 4100SUBS R0,R0,R4 4110MOVMI R0,#0 4120STRB R0,[R11],#1 ; write next byte 4130CMP R11,R12 4140SUBGE R11,R12,#sound_buf_size% ; wrap the pointer 4150SUBS R3,R3,#1 4160BHI sound_fillto_loop 4170ADR R4,sound_pitch0 4180STR R1,[R4,R5,LSL#2] ; save new pitch inc 4190.sound_fillto_end 4200SUB R12,R12,#sound_buf_size% 4210SUB R11,R11,R12 ; offset in buffer filled to 4220ADR R12,sound_filled0 4230STR R11,[R12,R5,LSL#2] 4240LDMFD R13!,{R1-R4,R11-R12,PC} 4250.sound_fillto_noise 4260LDR R2,sound_freq3 4270TST R2,#1<<2 ; look at FB 4280LDREQ R2,(sound_buffs_addr+8) 4290ADDEQ R2,R2,#&100 ; pulse sample 4300BEQ sound_fillto_loop ; periodic noise 4310STMFD R13!,{R6-R7} ; need two more registers 4320LDR R2,sound_noiseseed ; white noise seed 4330RSB R4,R4,#(127<<1) ; recover amplitude 4340EOR R0,R4,#1 ; other sign 4350LDR R6,sound_noiseeor ; eor 4360.sfn_loop ; white noise loop 4370MOV R7,R1 4380ADD R1,R1,R1,LSL#16 4390EOR R7,R7,R1 4400TST R7,#&40000000 4410BEQ sfn_skip ; bit hasn't changed so don't adv 4420MOVS R2,R2,LSR#1 4430EORCS R2,R2,R6 4440BICCC R1,R1,#&40000000 4450ORRCS R1,R1,#&40000000 4460.sfn_skip 4470TST R1,#&40000000 4480STREQB R0,[R11],#1 4490STRNEB R4,[R11],#1 4500CMP R11,R12 4510SUBGE R11,R12,#sound_buf_size% ; wrap the pointer 4520SUBS R3,R3,#1 4530BHI sfn_loop 4540LDMFD R13!,{R6-R7} 4550STR R2,sound_noiseseed 4560STR R1,sound_pitch3 4570B sound_fillto_end 4580.sound_fillto_speach ; direct amp modification 4590ADR R4,sound_amp0 4600LDRB R4,[R4,R5] ; get BBC amp for this channel 4610MOV R4,R4,LSL#1 ; 0-30 4620SUBS R4,R4,#15 ; amplitude -15 to 15 4630MOVPL R0,#0 4640MOVMI R0,#1 ; sign bit 4650RSBMI R4,R4,#0 ; now +ve (1-15) 4660LDR R1,(sound_buffs_addr+4) ; log amp table 4670LDRB R4,[R1,R4] ; VIDC amp 4680EOR R4,R4,R0 ; bung in sign to get sample 4690ADR R2,sound_time0 4700LDR R0,[R2,R5,LSL#2] ; get time last updated 4710.sound_fillto_speach_1 4720STRB R4,[R11],#1 4730SUB R0,R0,#96 4740CMP R11,R12 4750SUBGE R11,R12,#sound_buf_size% ; wrap the pointer 4760SUBS R3,R3,#1 4770BHI sound_fillto_speach_1 4780;STR R0,[R2,R5,LSL#2] 4790B sound_fillto_end 4800.sound_noiseseed EQUD &446D6954 ; white noise seed (R2) 4810.sound_noiseeor EQUD &82D4E1B8 ; white noise eor (R6) 4820 4830;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 4840; Voice generator ; 4850;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 4860 4870.sound_buffs_addr 4880EQUD 0 ; address of buffer 4890EQUD 0 ; volume table 4900EQUD 0 ; sample address 4910EQUD 0 ; stack address 4920 4930; SCCB 4940; #0 b0-b7 Arc volume (R1) 4950; #4 phase accumulator (b0-b15=inc) (R2) 4960; #8 - 4970; #12 number of buffer fills left to do (R4) 4980; #16 bbc channel number (0-3) (R5) 4990; #20 Volume scaled log amp table (R6) 5000 5010.sound_voiceheader 5020B sound_vfill 5030B sound_vfill 5040B sound_vfill 5050B sound_vgateoff 5060B sound_vinstantiate 5070LDMFD R13!,{PC} 5080LDMFD R13!,{PC} 5090EQUD sound_voicename-sound_voiceheader 5100.sound_voicename 5110EQUS "6502Emulator"+CHR$0 5120ALIGN 5130 5140;E Return address on stack 5150; R14 not usable (in IRQ mode) 5160 5170.sound_vfill 5180LDMFD R9,{R1-R6} ; R5=bbc channel number 5190ADR R1,sound_read0 5200LDR R2,[R1,R5,LSL#2] ; offset of unread data 5210ADR R1,sound_filled0 5220LDR R0,[R1,R5,LSL#2] ; offset buffer filled to 5230SUBS R0,R0,R2 5240ADDMI R0,R0,#sound_buf_size% ; amount in the buffer 5250RSBS R0,R0,#208 ; amount extra needed 5260BLE sound_fill_ret 5270ADR R1,sound_fill_ret 5280STMFD R13!,{R1} ; put return address on stack 5290B sound_fillto ; ensure the buffer full enough 5300.sound_fill_ret 5310ADR R1,sound_read0 5320LDR R0,[R1,R5,LSL#2] ; off of unread data 5330ADD R2,R0,#208 ; new offset after we've finished 5340CMP R2,#sound_buf_size% 5350SUBGE R2,R2,#sound_buf_size% ; wrap it 5360STR R2,[R1,R5,LSL#2] 5370LDR R2,sound_buffs_addr 5380ADD R2,R2,R5,LSL#sound_buf_size_log% ; address of buffer 5390ADD R3,R2,#sound_buf_size% ; end of buffer 5400ADD R2,R2,R0 ; current address 5410.sound_fill_loop ; NB Amp already scaled 5420LDRB R0,[R2],#1 ; get next byte 5430STRB R0,[R12],R11 5440CMP R2,R3 5450SUBGE R2,R3,#sound_buf_size% 5460LDRB R0,[R2],#1 ; get next byte 5470STRB R0,[R12],R11 5480CMP R2,R3 5490SUBGE R2,R3,#sound_buf_size% 5500LDRB R0,[R2],#1 ; get next byte 5510STRB R0,[R12],R11 5520CMP R2,R3 5530SUBGE R2,R3,#sound_buf_size% 5540LDRB R0,[R2],#1 ; get next byte 5550STRB R0,[R12],R11 5560CMP R2,R3 5570SUBGE R2,R3,#sound_buf_size% 5580CMP R12,R10 5590BLT sound_fill_loop 5600MOV R0,#8 ; voice still active 5610LDMFD R13!,{PC} 5620 5630;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 5640; print out debug data - current channel settings ; 5650;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 5660 5670;X R1=channel being changed 5680 5690.sound_debug 5700STMFD R13!,{R0-R1,R14} 5710SWI &11F 5720SWI &100 5730MOV R0,R1 5740SWI "XOS_WriteC" ; jump to row n 5750MOV R0,R1 5760BL sound_debug2 ; channel 5770ADR R14,sound_freq0 5780LDR R0,[R14,R1,LSL#2] 5790BL sound_debug2 ; freq 5800ADR R14,sound_amp0 5810LDRB R0,[R14,R1] 5820BL sound_debug2 ; amp 5830LDMFD R13!,{R0-R1,PC} 5840 5850] 5860="" 5870 5880REM MISC STUFF 5890 5900DEF FNsound_misc 5910[OPT p 5920 5930;E R0=number to print 5940;X Number printed 5950 5960.sound_debug2 ; output number in R0 to debug 5970STMFD R13!,{R0-R2,R14} 5980ADR R1,sound_debug_buf 5990MOV R2,#16 6000SWI "XOS_ConvertHex8" 6010SWI "XOS_Write0" 6020SWI &120 6030LDMFD R13!,{R0-R2,PC} 6040.sound_debug_buf 6050FNsound_mem(16) 6060 6070;E R0=channel number-1 (0-7) 6080; Return address on top of stack 6090 6100.sound_vinstantiate 6110STMFD R13!,{R0-R5} 6120MOV R5,R0 ; save channel number 6130MOV R0,#0 6140MOV R1,#0 6150MOV R2,#0 6160MOV R3,#0 6170MOV R4,#0 6180SWI "XSound_Configure" 6190ADD R0,R5,#1 ; channel number 6200MOV R1,#20 6210LDR R2,[R3,#12] 6220SWI "XSound_WriteControlBlock" ; volume scaled log amp 6230ADD R0,R5,#1 6240MOV R1,#16 6250MOV R2,R5 ; bbc channel number 6260CMP R2,#4 6270MOVCS R2,#0 ; clip 6280SWI "XSound_WriteControlBlock" 6290LDMFD R13!,{R0-R5,PC} 6300 6310.sound_vgateoff 6320MOV R0,#0 6330.sound_gateoff_loop 6340STRB R0,[R12],R11 6350STRB R0,[R12],R11 6360STRB R0,[R12],R11 6370STRB R0,[R12],R11 6380CMP R12,R10 6390BLT sound_gateoff_loop 6400MOV R0,#1 6410LDMFD R13!,{PC} 6420 6430;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 6440; Divide routine ; 6450;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 6460 6470\E R0=numerator R1=denominator 6480\X R0=R0 Div R1 R2=R0 Mod R1 R0-R3 corrupted | 6490 6500.div_mod 6510MOV R2,#0 \ clear remainder 6520ADDS R0,R0,R0 \ double numerator 6530RSB R1,R1,#0 \ negate denom 6540MOV R3,#32 6550.div_mod_1 6560ADCS R2,R1,R2,LSL#1:SUBCC R2,R2,R1:ADCS R0,R0,R0 6570ADCS R2,R1,R2,LSL#1:SUBCC R2,R2,R1:ADCS R0,R0,R0 6580ADCS R2,R1,R2,LSL#1:SUBCC R2,R2,R1:ADCS R0,R0,R0 6590ADCS R2,R1,R2,LSL#1:SUBCC R2,R2,R1:ADCS R0,R0,R0 6600SUB R3,R3,#4 6610TEQ R3,#0 6620BNE div_mod_1 \ DO NOT CORRUPT CARRY 6630MOVS PC,R14 6640 6650.log_start 6660STMFD R13!,{R0-R2,R14} 6670MOV R0,#&88 6680ADR R1,log_fname 6690SWI "OS_Find" 6700STR R0,log_handle 6710LDMFD R13!,{R0-R2,PC} 6720.log_fname EQUS "$.TMP.LogFile"+CHR$0 6730ALIGN 6740.log_handle EQUD 0 6750.log_temp EQUD 0 6760 6770.log_end 6780STMFD R13!,{R0-R2,R14} 6790MOV R0,#0 6800LDR R1,log_handle 6810SWI "OS_Find" 6820LDMFD R13!,{R0-R2,PC} 6830 6840; R0=word to log 6850 6860.log_word 6870STMFD R13!,{R0-R5,R14} 6880STR R0,log_temp 6890MOV R0,#2 6900LDR R1,log_handle 6910ADR R2,log_temp 6920MOV R3,#4 6930SWI "OS_GBPB" 6940LDMFD R13!,{R0-R5,PC} 6950 6960] 6970="" 6980 6990DEF FNsound_mem(a%) 7000P%+=a%:O%+=a% 7010=""
� > Sound5 � ,� BBC Sound and Speech emulation library (%� For Mike Borcherds BBC emulator 2 � This file by Dominic Symes < F� Set up global defaults P� �sound_define Z.� Size of circular buffer for each channel dsound_buf_size_log%=10 n,sound_buf_size%=(1<<sound_buf_size_log%) x� � �!� Call to set up sound tables �� �sound_init � � a,f% ��sound_define ��volume%=127 �'� sound_buffer% (4*sound_buf_size%) �� sound_vol_table% &40 �� sound_sample% &200 �� sound_stack% &80 �� f%=0 � &3FF �?(sound_buffer%+f%)=f%*10 �� "ș "Sound_Volume",127 � sc_vol ?� Set up sound sample for pitch channels - half way between 6� a sine wave and square wave gives best likeness. "� f%=0 � &7F ,ș "6502_Sound",f%,A% 6a=�((f%/128)*�) @� a<>0 � a=a^.2 J'ș "Sound_SoundLog",&7FFFFFFF*a � a T?(sound_sample%+f%)=a ^?(sound_sample%+&80+f%)=a+1 h� r5� Set up the sound sample for the pulse generator |� f%=0 � &3F �6?(sound_sample%+&100+f%)=?(sound_sample%+f%*(8/4)) �� �� f%=0 � &BF �;?(sound_sample%+&110+f%)=?(sound_sample%+&80+f%*(8/12)) �� �ș "Sound_Volume",sc_vol �"sound_voice%=code+!(code+22*4) �#!(sound_voice%+0)=sound_buffer% �&!(sound_voice%+4)=sound_vol_table% �#!(sound_voice%+8)=sound_sample% �'!(sound_voice%+12)=sound_stack%+&40 �sound_voice%+=16 �� ��sound_reinit "sound_voice%=code+!(code+22*4) &#!(sound_voice%+0)=sound_buffer% 0&!(sound_voice%+4)=sound_vol_table% :#!(sound_voice%+8)=sound_sample% D'!(sound_voice%+12)=sound_stack%+&40 Nsound_voice%+=16 X� b l,� Call just before starting the emulator v� �sound_setup �� f%,a% �?ș "Sound_InstallVoice",sound_voice%,0 � ,sound_voice_slot% �@ș "Sound_Configure",4,208,48,0,0 � sc_0,sc_1,sc_2,sc_3,sc_4 �&ș "Sound_AttachVoice",1,1 � ,sv_1 �&ș "Sound_AttachVoice",2,1 � ,sv_2 �&ș "Sound_AttachVoice",3,1 � ,sv_3 �&ș "Sound_AttachVoice",4,1 � ,sv_4 �0ș "Sound_AttachNamedVoice",1,"6502Emulator" �0ș "Sound_AttachNamedVoice",2,"6502Emulator" �0ș "Sound_AttachNamedVoice",3,"6502Emulator" �0ș "Sound_AttachNamedVoice",4,"6502Emulator" �;� Start infinite duration notes on each of the channels �&ș "Sound_Volume",volume% � sc_vol 0� Set up the linear to log volume conversion � f%=0 � &F a%=f%+(f%<<4) a%=a%+(a%<<8) *a%=a%+(a%<<16) 4%ș "Sound_SoundLog",(a%>>>1) � a% > �PRINT a% H?(sound_vol_table%+f%)=a% R� \� 1,-1,1,255 f� 2,-1,1,255 p� 3,-1,1,255 z� 4,-1,1,255 �� � �%� Call after exiting the emulator �� �sound_restore �ș "Sound_Volume",sc_vol �1ș "Sound_Configure",sc_0,sc_1,sc_2,sc_3,sc_4 �!ș "Sound_AttachVoice",1,sv_1 �!ș "Sound_AttachVoice",2,sv_2 �!ș "Sound_AttachVoice",3,sv_3 �!ș "Sound_AttachVoice",4,sv_4 �.ș "Sound_RemoveVoice",0,sound_voice_slot% �� � 0� Code to interpret writes to the sound chip 7� mem=3 A=4 X=5 Y=6 F=7 SP=8 time=9 zpc=10 table=11 � p=pass $� �sound_latch .�sound_define 8 [OPT p B L@; the following byte should be written by regb_4f and should V0; hold a copy of what's on the slow data bus ` j.sound_data EQUD 0 t ~; Notes: �E; Clock is 2Mhz. One buffer fill every 48 micro secs = 96 cycles. �C; Pitch phase increment = &60000 / (10 bit BBC sound chip freq) �@; Cleary greatest sensible pitch increment is &4000, so very �;; small BBC frequencies are conventionally meaningless. �.; A BBC frequency of 1 is assumed to be an �=; attempt to modulate the amplitude manually (eg Superior �2; Software speech) and is handled accordingly. � �2;E Called when latch writes to sound generator �A; sound_data contains a copy of the byte written to the slow �; data bus �*; R0=value written to latch (b0-b2=0) "; R3=BBC memory address (mem) 3; R9=time in cycles until next clock interrupt ;X R0-R2,R13 corrupted ; Exits via MOV PC,R14 ( 2.sound_latch <STR mem,memstore FTST R0,#1<<3 P.MOVNE PC,R14 ; active low Z!LDR R13,(sound_buffs_addr+12) dSTMFD R13!,{R3,R14} n8LDRB R0,sound_data ; get the byte written xTST R0,#1<<7 �8BEQ sound_update ; update the frequency �MOV R1,R0,LSR#5 �B� R1,R1,#3 ; channel number (0=tone3 3=noise) �TST R0,#1<<4 �2� R0,R0,#&0F ; data is in b0-b3 �2BNE sound_volume ; volume control �2TEQ R1,#3 ; noise channel? �>STRNE R1,sound_channel ; if not set current channel �ADR R14,sound_freq0 �=LDR R3,[R14,R1,LSL#2] ; get the current frequency �7BIC R2,R3,#&0F ; clear bottom 4 bits �0�R R2,R2,R0 ; new frequency �1STR R2,[R14,R1,LSL#2] ; new frequency B sound_frequency 4.sound_update ; update frequency 3LDR R1,sound_channel ; current channel "ADR R14,sound_freq0 ,=LDR R3,[R14,R1,LSL#2] ; get the current frequency 64� R2,R3,#&0F ; loose the top bits @4� R0,R0,#&3F ; b4-b9 of frequency J:�R R2,R2,R0,LSL#4 ; add new high order bits T1STR R2,[R14,R1,LSL#2] ; new frequency ^B sound_frequency h>;NB not sure whether you should update sound_channel here? r<.sound_volume ; R0=volume (15 off-0 max) |=RSB R0,R0,#15 ; new vol 0=off 15=max now! �ADR R14,sound_amp0 �.LDRB R2,[R14,R1] ; old volume � TEQ R0,R2 �:;BEQ sound_latch_end ; volume hasn't changed �8STRB R0,[R14,R1] ; write the new volume � TEQ R1,#3 �8BEQ sound_latch_end ; ignore noise channel �ADR R14,sound_freq0 �9LDR R0,[R14,R1,LSL#2] ; get frequency setting � TEQ R0,#1 �/BLEQ make_sound ; it's speech �B sound_latch_end �C.sound_frequency ; R1=channel R2=new freq (10 bit) 8TEQ R1,#3 ; R3=old freq (10 bit) ?BLEQ sound_noisefreq ; Convert R2 to 10 bit format 4TEQ R2,#1 ; check for speach &BEQ sound_speach_start 0 TEQ R3,#1 :BLEQ sound_speach_stop DMOV R0,#&60000 N7STMFD R13!,{R1} ; save channel number X/MOV R1,R2 ; denomenator bDBL div_mod ; R0=pitch accumulator inc corr R3 l:LDMFD R13!,{R1} ; restore channel number v CMP R0,#0 �MOVLE R0,#0 �CMP R0,#&4000 �:MOVGE R0,#&4000 ; R0=new pitch increment �ADR R14,sound_pitch0 �LDR R2,[R14,R1,LSL#2] �MOV R2,R2,LSR#16 �>�R R2,R0,R2,LSL#16 ; install new pitch increment �STR R2,[R14,R1,LSL#2] �9TEQ R1,#2 ; is it pitch channel 1 �&BNE sound_latch_end ; no �DLDR R0,sound_freq3 ; 3 bit freq setting of noise chan �� R0,R0,#3 �=TEQ R0,#3 ; is it based on channel 1? &BNE sound_latch_end ; no ;BL sound_debug -MOV R1,#3 ; channel 0 >LDR R2,sound_freq3 ; channel 0 10-bit frequency *BB sound_frequency ; update frequency for channel 0 4(.sound_latch_end ; EXIT >8;BL sound_debug ; print up debug data H(LDMFD R13!,{R3,PC} ; EXIT R.sound_speach_start \ TEQ R3,#1 f3BEQ sound_latch_end ; already started pBL sound_get_time zADR R0,sound_time0 �BSTR R2,[R0,R1,LSL#2] ; time this channel last updated � TEQ R1,#0 �;BLEQ log_start �B sound_latch_end � �;E Called when speach stops �;X Corrupts R0 � �.sound_speach_stop � TEQ R1,#0 �;BEQ log_end �MOV PC,R14 � .memstore EQUD 0 $(;E R9=Emulator time 'till next event .;;X R2=current time on the sound decrementing 2MHz clock 8; R0 corrupted B L.sound_get_time VLDR R0,memstore `LDR R2,[R0,#min] j@SUB R2,R2,R9 ; time passed since last event tLDR R0,[R0,#sound_timer] ~>SUB R2,R0,R2 ; current time (dec at 2Mhz) �MOV PC,R14 � �>;E Volume changed (not just been set to the same value!!!) �#; This channel in speech mode. �*; R2=the old volume before the change �*; R1=BBC channel number (0-3) R9=time �4;X Buffer filled for manual amplitude modulation �; R0 corrupted � �.make_sound �STMFD R13!,{R1-R5,R14} �; TEQ R1,#0 ; LDMNEFD R13!,{R1-R5,PC} ; LDRB R0,[mem,#&67] ; LDRB R14,[mem,#&68] ; ADD R0,R0,R14,LSL#8 (; LDRB R14,[R0,Y,LSR#24] 2; ADD R0,R0,Y <; ADD R0,R0,R14,LSL#16 F; LDR R0,[mem,#&60] P; BL log_word Z; MOV R0,R2 d; BL log_word n2MOV R4,R2,LSL#1 ; amplitude 0-30 x7SUBS R4,R4,#15 ; amplitude -15 to 15 �MOVPL R0,#0 �,MOVMI R0,#1 ; sign bit �2RSBMI R4,R4,#0 ; now +ve (1-15) �1LDR R14,(sound_buffs_addr+4) ; log amp table �,LDRB R4,[R14,R4] ; VIDC amp �<� R4,R4,R0 ; bung in sign to get sample �3BL sound_get_time ; R2=current time �ADR R14,sound_time0 �BLDR R3,[R14,R1,LSL#2] ; time this channel last updated �ASUBS R0,R3,R2 ; time passed since last update �9MOVMI R3,R2 ; clip if gone negative �ACMP R0,#&C000 ; greater than one buffer fill? �.ADDGE R3,R2,#&C000 ; clip if so ; BL log_word ADR R14,sound_filled0 @LDR R5,[R14,R1,LSL#2] ; current offset in the buffer ".make_sound_1 ,ADR R14,sound_read0 62LDR R0,[R14,R1,LSL#2] ; amount read to @SUBS R0,R5,R0 J8ADDMI R0,R0,#sound_buf_size% ; amount in the buffer TCMP R0,#512 ^?BGT make_sound_1 ; wait for output to catch up hLDR R0,sound_buffs_addr r<ADD R0,R0,R1,LSL#sound_buf_size_log% ; address of buffer |.make_sound_2 �;SUB R3,R3,#96 ; try and do another byte � CMP R3,R2 �)BLT make_sound_3 ; can't �4STRB R4,[R0,R5] ; write out a byte �; STMFD R13!,{R0} �; MOV R0,R4 �; BL log_word �; LDMFD R13!,{R0} �ADD R5,R5,#1 �CMP R5,#sound_buf_size% �6MOVGE R5,#0 ; wrap buffer offset �B make_sound_2 �.make_sound_3 ADD R3,R3,#96 ADR R14,sound_filled0 5STR R5,[R14,R1,LSL#2] ; new buffer offset &ADR R14,sound_time0 09STR R3,[R14,R1,LSL#2] ; new time last updated :LDMFD R13!,{R1-R5,PC} D N.;E R2=noise channel frequency (bbc format) X*;X R2=noise channel frequnecy (10 bit) b; Corrupts R0 l=; Don't need to clip since pitch inc can go up to &60000 v �.sound_noisefreq �� R0,R2,#3 � TEQ R0,#3 �BEQ sound_usefreq2 �,� R0,R2,#7 ; FB NF1 NF0 �ADR R2,sound_noisetab �LDR R2,[R2,R0,LSL#2] �MOV PC,R14 �.sound_usefreq2 � TST R2,#4 �BLDR R2,sound_freq2 ; use tone generator 1 frequency �;;�Q R2,R2,LSL#4 ; multiply if pulse channel �<;MOVNE R2,R2,LSR#2 ; divide if noise channel � �4MOV R2,R2,LSL#4 ; changed 11/96 MRB � *MOV PC,R14 4.sound_noisetab >.EQUD &F1 ; pulse high H-EQUD &1D5 ; pulse med R-EQUD &3C6 ; pulse low \ EQUD 0 f.EQUD &1F ; noise high p-EQUD &A3 ; noise med z-EQUD &100 ; noise low � EQUD 0 � �>.sound_channel EQUD 0 ; current note channel (0-2) �C.sound_freq0 EQUD 0 ; frequency of channel 3 (10 bit) �:.sound_freq1 EQUD 0 ; frequency of channel 2 �:.sound_freq2 EQUD 0 ; frequency of channel 1 �E.sound_freq3 EQUD 0 ; frequency of channel 0 X FB NF1,0 �?.sound_amp0 EQUB 0 ; amplitude of channel 3 0-15 �:.sound_amp1 EQUB 0 ; amplitude of channel 2 �:.sound_amp2 EQUB 0 ; amplitude of channel 1 �:.sound_amp3 EQUB 0 ; amplitude of channel 0 �@.sound_read0 EQUD 0 ; offset in buffer of start of �/.sound_read1 EQUD 0 ; unread data 0.sound_read2 EQUD 0 ; channels 0-3 #.sound_read3 EQUD 0 ; C.sound_filled0 EQUD 0 ; offset in buf filled to chann 0 $C.sound_filled1 EQUD 0 ; offset in buf filled to chann 1 .C.sound_filled2 EQUD 0 ; offset in buf filled to chann 2 8C.sound_filled3 EQUD 0 ; offset in buf filled to chann 3 B9.sound_pitch0 EQUD 0 ; phase pitch channel 0 L9.sound_pitch1 EQUD 0 ; phase pitch channel 1 V9.sound_pitch2 EQUD 0 ; phase pitch channel 2 `9.sound_pitch3 EQUD 0 ; phase pitch channel 3 jB.sound_time0 EQUD 0 ; last time (R9) channel updated tA.sound_time1 EQUD 0 ; channel 1 (decrements as time ~7.sound_time2 EQUD 0 ; channel 2 goes on) �-.sound_time3 EQUD 0 ; channel 3 � �7;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; �7; Fill sound buffer ; �7;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; � �+;E R0=number of bytes to fill in buffer �; R5=bbc channel number �#; R14 not usable (in IRQ mode) �; Return address on stack � �.sound_fillto STMFD R13!,{R1-R4,R11-R12} 9ADDS R3,R0,#0 ; number of bytes to do *LDMLEFD R13!,{R1-R4,R11-R12,PC} ; none ADR R4,sound_filled0 (<LDR R1,[R4,R5,LSL#2] ; current offset filled to 2LDR R11,sound_buffs_addr <BADD R11,R11,R5,LSL#sound_buf_size_log% ; address of the buffer F5ADD R12,R11,#sound_buf_size% ; end of the buffer PEADD R11,R11,R1 ; address at which to start filling ZADR R4,sound_pitch0 d7LDR R1,[R4,R5,LSL#2] ; get phase pitch inc nADR R4,sound_amp0 x@LDRB R4,[R4,R5] ; get BBC amp for this channel �8LDR R0,(sound_buffs_addr+4) ; volume scaling table �?LDRB R4,[R0,R4] ; scale volume to VIDC format �/RSB R4,R4,#(127<<1) ; attenuation �2TEQ R5,#3 ; noise channel? �BEQ sound_fillto_noise �ADR R0,sound_freq0 �LDR R0,[R0,R5,LSL#2] � TEQ R0,#1 �BEQ sound_fillto_speach �3LDR R2,(sound_buffs_addr+8) ; standard sample �.sound_fillto_loop �4ADD R1,R1,R1,LSL#16 ; advance waveform �LDRB R0,[R2,R1,LSR#24] SUBS R0,R0,R4 MOVMI R0,#0 3STRB R0,[R11],#1 ; write next byte "CMP R11,R12 ,5SUBGE R11,R12,#sound_buf_size% ; wrap the pointer 6SUBS R3,R3,#1 @BHI sound_fillto_loop JADR R4,sound_pitch0 T6STR R1,[R4,R5,LSL#2] ; save new pitch inc ^.sound_fillto_end h SUB R12,R12,#sound_buf_size% r>SUB R11,R11,R12 ; offset in buffer filled to |ADR R12,sound_filled0 �STR R11,[R12,R5,LSL#2] �!LDMFD R13!,{R1-R4,R11-R12,PC} �.sound_fillto_noise �LDR R2,sound_freq3 �.TST R2,#1<<2 ; look at FB �!LDREQ R2,(sound_buffs_addr+8) �0ADDEQ R2,R2,#&100 ; pulse sample �2BEQ sound_fillto_loop ; periodic noise �;STMFD R13!,{R6-R7} ; need two more registers �4LDR R2,sound_noiseseed ; white noise seed �5RSB R4,R4,#(127<<1) ; recover amplitude �,� R0,R4,#1 ; other sign �'LDR R6,sound_noiseeor ; eor 4.sfn_loop ; white noise loop MOV R7,R1 ADD R1,R1,R1,LSL#16 &� R7,R7,R1 0TST R7,#&40000000 :CBEQ sfn_skip ; bit hasn't changed so don't adv DMOVS R2,R2,LSR#1 N�CS R2,R2,R6 XBICCC R1,R1,#&40000000 b�RCS R1,R1,#&40000000 l .sfn_skip vTST R1,#&40000000 �STREQB R0,[R11],#1 �STRNEB R4,[R11],#1 �CMP R11,R12 �5SUBGE R11,R12,#sound_buf_size% ; wrap the pointer �SUBS R3,R3,#1 �BHI sfn_loop �LDMFD R13!,{R6-R7} �STR R2,sound_noiseseed �STR R1,sound_pitch3 �B sound_fillto_end �;.sound_fillto_speach ; direct amp modification �ADR R4,sound_amp0 �@LDRB R4,[R4,R5] ; get BBC amp for this channel (MOV R4,R4,LSL#1 ; 0-30 7SUBS R4,R4,#15 ; amplitude -15 to 15 MOVPL R0,#0 ,MOVMI R0,#1 ; sign bit *2RSBMI R4,R4,#0 ; now +ve (1-15) 41LDR R1,(sound_buffs_addr+4) ; log amp table >,LDRB R4,[R1,R4] ; VIDC amp H<� R4,R4,R0 ; bung in sign to get sample RADR R2,sound_time0 \9LDR R0,[R2,R5,LSL#2] ; get time last updated f.sound_fillto_speach_1 pSTRB R4,[R11],#1 zSUB R0,R0,#96 �CMP R11,R12 �5SUBGE R11,R12,#sound_buf_size% ; wrap the pointer �SUBS R3,R3,#1 �BHI sound_fillto_speach_1 �;STR R0,[R2,R5,LSL#2] �B sound_fillto_end �;.sound_noiseseed EQUD &446D6954 ; white noise seed (R2) �:.sound_noiseeor EQUD &82D4E1B8 ; white noise eor (R6) � �7;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; �7; Voice generator ; �7;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; � .sound_buffs_addr 5EQUD 0 ; address of buffer 0EQUD 0 ; volume table $2EQUD 0 ; sample address .1EQUD 0 ; stack address 8 B ; SCCB L; #0 b0-b7 Arc volume (R1) V,; #4 phase accumulator (b0-b15=inc) (R2) ` ; #8 - j0; #12 number of buffer fills left to do (R4) t'; #16 bbc channel number (0-3) (R5) ~*; #20 Volume scaled log amp table (R6) � �.sound_voiceheader �B sound_vfill �B sound_vfill �B sound_vfill �B sound_vgateoff �B sound_vinstantiate �LDMFD R13!,{PC} �LDMFD R13!,{PC} �*EQUD sound_voicename-sound_voiceheader �.sound_voicename �EQUS "6502Emulator"+�0 ALIGN ;E Return address on stack #; R14 not usable (in IRQ mode) ( 2.sound_vfill <9LDMFD R9,{R1-R6} ; R5=bbc channel number FADR R1,sound_read0 P9LDR R2,[R1,R5,LSL#2] ; offset of unread data ZADR R1,sound_filled0 d;LDR R0,[R1,R5,LSL#2] ; offset buffer filled to nSUBS R0,R0,R2 x8ADDMI R0,R0,#sound_buf_size% ; amount in the buffer �7RSBS R0,R0,#208 ; amount extra needed �BLE sound_fill_ret �ADR R1,sound_fill_ret �?STMFD R13!,{R1} ; put return address on stack �AB sound_fillto ; ensure the buffer full enough �.sound_fill_ret �ADR R1,sound_read0 �6LDR R0,[R1,R5,LSL#2] ; off of unread data �CADD R2,R0,#208 ; new offset after we've finished �CMP R2,#sound_buf_size% �+SUBGE R2,R2,#sound_buf_size% ; wrap it �STR R2,[R1,R5,LSL#2] �LDR R2,sound_buffs_addr <ADD R2,R2,R5,LSL#sound_buf_size_log% ; address of buffer 1ADD R3,R2,#sound_buf_size% ; end of buffer 3ADD R2,R2,R0 ; current address "9.sound_fill_loop ; NB Amp already scaled ,1LDRB R0,[R2],#1 ; get next byte 6STRB R0,[R12],R11 @ CMP R2,R3 J SUBGE R2,R3,#sound_buf_size% T1LDRB R0,[R2],#1 ; get next byte ^STRB R0,[R12],R11 h CMP R2,R3 r SUBGE R2,R3,#sound_buf_size% |1LDRB R0,[R2],#1 ; get next byte �STRB R0,[R12],R11 � CMP R2,R3 � SUBGE R2,R3,#sound_buf_size% �1LDRB R0,[R2],#1 ; get next byte �STRB R0,[R12],R11 � CMP R2,R3 � SUBGE R2,R3,#sound_buf_size% �CMP R12,R10 �BLT sound_fill_loop �6MOV R0,#8 ; voice still active �LDMFD R13!,{PC} � �7;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 7; print out debug data - current channel settings ; 7;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; &;X R1=channel being changed 0 :.sound_debug DSTMFD R13!,{R0-R1,R14} NSWI &11F XSWI &100 b MOV R0,R1 l1SWI "XOS_WriteC" ; jump to row n v MOV R0,R1 �+BL sound_debug2 ; channel �ADR R14,sound_freq0 �LDR R0,[R14,R1,LSL#2] �(BL sound_debug2 ; freq �ADR R14,sound_amp0 �LDRB R0,[R14,R1] �'BL sound_debug2 ; amp �LDMFD R13!,{R0-R1,PC} � �] �="" � �� MISC STUFF � �sound_misc [OPT p *;E R0=number to print 4;X Number printed > H6.sound_debug2 ; output number in R0 to debug RSTMFD R13!,{R0-R2,R14} \ADR R1,sound_debug_buf fMOV R2,#16 pSWI "XOS_ConvertHex8" zSWI "XOS_Write0" �SWI &120 �LDMFD R13!,{R0-R2,PC} �.sound_debug_buf ��sound_mem(16) � � ;E R0=channel number-1 (0-7) �%; Return address on top of stack � �.sound_vinstantiate �STMFD R13!,{R0-R5} �7MOV R5,R0 ; save channel number � MOV R0,#0 � MOV R1,#0 MOV R2,#0 MOV R3,#0 MOV R4,#0 $SWI "XSound_Configure" .2ADD R0,R5,#1 ; channel number 8MOV R1,#20 BLDR R2,[R3,#12] LCSWI "XSound_WriteControlBlock" ; volume scaled log amp VADD R0,R5,#1 `MOV R1,#16 j6MOV R2,R5 ; bbc channel number t CMP R2,#4 ~(MOVCS R2,#0 ; clip �"SWI "XSound_WriteControlBlock" �LDMFD R13!,{R0-R5,PC} � �.sound_vgateoff � MOV R0,#0 �.sound_gateoff_loop �STRB R0,[R12],R11 �STRB R0,[R12],R11 �STRB R0,[R12],R11 �STRB R0,[R12],R11 �CMP R12,R10 �BLT sound_gateoff_loop MOV R0,#1 LDMFD R13!,{PC} 7;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (7; Divide routine ; 27;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; < F$\E R0=numerator R1=denominator P7\X R0=R0 Div R1 R2=R0 Mod R1 R0-R3 corrupted | Z d.div_mod n3MOV R2,#0 \ clear remainder x4ADDS R0,R0,R0 \ double numerator �0RSB R1,R1,#0 \ negate denom �MOV R3,#32 �.div_mod_1 �4ADCS R2,R1,R2,LSL#1:SUBCC R2,R2,R1:ADCS R0,R0,R0 �4ADCS R2,R1,R2,LSL#1:SUBCC R2,R2,R1:ADCS R0,R0,R0 �4ADCS R2,R1,R2,LSL#1:SUBCC R2,R2,R1:ADCS R0,R0,R0 �4ADCS R2,R1,R2,LSL#1:SUBCC R2,R2,R1:ADCS R0,R0,R0 �SUB R3,R3,#4 � TEQ R3,#0 �6BNE div_mod_1 \ DO � CORRUPT CARRY �MOVS PC,R14 � �.log_start STMFD R13!,{R0-R2,R14} MOV R0,#&88 ADR R1,log_fname "SWI "OS_Find" ,STR R0,log_handle 6LDMFD R13!,{R0-R2,PC} @&.log_fname EQUS "$.TMP.LogFile"+�0 J ALIGN T.log_handle EQUD 0 ^.log_temp EQUD 0 h r.log_end |STMFD R13!,{R0-R2,R14} � MOV R0,#0 �LDR R1,log_handle �SWI "OS_Find" �LDMFD R13!,{R0-R2,PC} � �; R0=word to log � � .log_word �STMFD R13!,{R0-R5,R14} �STR R0,log_temp � MOV R0,#2 �LDR R1,log_handle �ADR R2,log_temp MOV R3,#4 SWI "OS_GBPB" LDMFD R13!,{R0-R5,PC} & 0] :="" D N� �sound_mem(a%) XP%+=a%:O%+=a% b="" �
00000000 0d 00 0a 0e f4 20 3e 20 53 6f 75 6e 64 35 0d 00 |..... > Sound5..| 00000010 14 05 f4 0d 00 1e 2c f4 20 42 42 43 20 53 6f 75 |......,. BBC Sou| 00000020 6e 64 20 61 6e 64 20 53 70 65 65 63 68 20 65 6d |nd and Speech em| 00000030 75 6c 61 74 69 6f 6e 20 6c 69 62 72 61 72 79 0d |ulation library.| 00000040 00 28 25 f4 20 46 6f 72 20 4d 69 6b 65 20 42 6f |.(%. For Mike Bo| 00000050 72 63 68 65 72 64 73 20 42 42 43 20 65 6d 75 6c |rcherds BBC emul| 00000060 61 74 6f 72 0d 00 32 20 f4 20 54 68 69 73 20 66 |ator..2 . This f| 00000070 69 6c 65 20 62 79 20 44 6f 6d 69 6e 69 63 20 53 |ile by Dominic S| 00000080 79 6d 65 73 0d 00 3c 04 0d 00 46 1c f4 20 53 65 |ymes..<...F.. Se| 00000090 74 20 75 70 20 67 6c 6f 62 61 6c 20 64 65 66 61 |t up global defa| 000000a0 75 6c 74 73 0d 00 50 13 dd 20 f2 73 6f 75 6e 64 |ults..P.. .sound| 000000b0 5f 64 65 66 69 6e 65 0d 00 5a 2e f4 20 53 69 7a |_define..Z.. Siz| 000000c0 65 20 6f 66 20 63 69 72 63 75 6c 61 72 20 62 75 |e of circular bu| 000000d0 66 66 65 72 20 66 6f 72 20 65 61 63 68 20 63 68 |ffer for each ch| 000000e0 61 6e 6e 65 6c 0d 00 64 1a 73 6f 75 6e 64 5f 62 |annel..d.sound_b| 000000f0 75 66 5f 73 69 7a 65 5f 6c 6f 67 25 3d 31 30 0d |uf_size_log%=10.| 00000100 00 6e 2c 73 6f 75 6e 64 5f 62 75 66 5f 73 69 7a |.n,sound_buf_siz| 00000110 65 25 3d 28 31 3c 3c 73 6f 75 6e 64 5f 62 75 66 |e%=(1<<sound_buf| 00000120 5f 73 69 7a 65 5f 6c 6f 67 25 29 0d 00 78 05 e1 |_size_log%)..x..| 00000130 0d 00 82 04 0d 00 8c 21 f4 20 43 61 6c 6c 20 74 |.......!. Call t| 00000140 6f 20 73 65 74 20 75 70 20 73 6f 75 6e 64 20 74 |o set up sound t| 00000150 61 62 6c 65 73 0d 00 96 11 dd 20 f2 73 6f 75 6e |ables..... .soun| 00000160 64 5f 69 6e 69 74 0d 00 a0 0a ea 20 61 2c 66 25 |d_init..... a,f%| 00000170 0d 00 aa 11 f2 73 6f 75 6e 64 5f 64 65 66 69 6e |.....sound_defin| 00000180 65 0d 00 b4 10 f4 76 6f 6c 75 6d 65 25 3d 31 32 |e.....volume%=12| 00000190 37 0d 00 be 27 de 20 73 6f 75 6e 64 5f 62 75 66 |7...'. sound_buf| 000001a0 66 65 72 25 20 28 34 2a 73 6f 75 6e 64 5f 62 75 |fer% (4*sound_bu| 000001b0 66 5f 73 69 7a 65 25 29 0d 00 c8 1a de 20 73 6f |f_size%)..... so| 000001c0 75 6e 64 5f 76 6f 6c 5f 74 61 62 6c 65 25 20 26 |und_vol_table% &| 000001d0 34 30 0d 00 d2 18 de 20 73 6f 75 6e 64 5f 73 61 |40..... sound_sa| 000001e0 6d 70 6c 65 25 20 26 32 30 30 0d 00 dc 16 de 20 |mple% &200..... | 000001f0 73 6f 75 6e 64 5f 73 74 61 63 6b 25 20 26 38 30 |sound_stack% &80| 00000200 0d 00 e6 11 e3 20 66 25 3d 30 20 b8 20 26 33 46 |..... f%=0 . &3F| 00000210 46 0d 00 f0 1d 3f 28 73 6f 75 6e 64 5f 62 75 66 |F....?(sound_buf| 00000220 66 65 72 25 2b 66 25 29 3d 66 25 2a 31 30 0d 00 |fer%+f%)=f%*10..| 00000230 fa 05 ed 0d 01 04 22 c8 99 20 22 53 6f 75 6e 64 |......".. "Sound| 00000240 5f 56 6f 6c 75 6d 65 22 2c 31 32 37 20 b8 20 73 |_Volume",127 . s| 00000250 63 5f 76 6f 6c 0d 01 0e 3f f4 20 53 65 74 20 75 |c_vol...?. Set u| 00000260 70 20 73 6f 75 6e 64 20 73 61 6d 70 6c 65 20 66 |p sound sample f| 00000270 6f 72 20 70 69 74 63 68 20 63 68 61 6e 6e 65 6c |or pitch channel| 00000280 73 20 2d 20 68 61 6c 66 20 77 61 79 20 62 65 74 |s - half way bet| 00000290 77 65 65 6e 0d 01 18 36 f4 20 61 20 73 69 6e 65 |ween...6. a sine| 000002a0 20 77 61 76 65 20 61 6e 64 20 73 71 75 61 72 65 | wave and square| 000002b0 20 77 61 76 65 20 67 69 76 65 73 20 62 65 73 74 | wave gives best| 000002c0 20 6c 69 6b 65 6e 65 73 73 2e 0d 01 22 10 e3 20 | likeness...".. | 000002d0 66 25 3d 30 20 b8 20 26 37 46 0d 01 2c 19 c8 99 |f%=0 . &7F..,...| 000002e0 20 22 36 35 30 32 5f 53 6f 75 6e 64 22 2c 66 25 | "6502_Sound",f%| 000002f0 2c 41 25 0d 01 36 13 61 3d b5 28 28 66 25 2f 31 |,A%..6.a=.((f%/1| 00000300 32 38 29 2a af 29 0d 01 40 13 e7 20 61 3c 3e 30 |28)*.)..@.. a<>0| 00000310 20 8c 20 61 3d 61 5e 2e 32 0d 01 4a 27 c8 99 20 | . a=a^.2..J'.. | 00000320 22 53 6f 75 6e 64 5f 53 6f 75 6e 64 4c 6f 67 22 |"Sound_SoundLog"| 00000330 2c 26 37 46 46 46 46 46 46 46 2a 61 20 b8 20 61 |,&7FFFFFFF*a . a| 00000340 0d 01 54 19 3f 28 73 6f 75 6e 64 5f 73 61 6d 70 |..T.?(sound_samp| 00000350 6c 65 25 2b 66 25 29 3d 61 0d 01 5e 1f 3f 28 73 |le%+f%)=a..^.?(s| 00000360 6f 75 6e 64 5f 73 61 6d 70 6c 65 25 2b 26 38 30 |ound_sample%+&80| 00000370 2b 66 25 29 3d 61 2b 31 0d 01 68 05 ed 0d 01 72 |+f%)=a+1..h....r| 00000380 35 f4 20 53 65 74 20 75 70 20 74 68 65 20 73 6f |5. Set up the so| 00000390 75 6e 64 20 73 61 6d 70 6c 65 20 66 6f 72 20 74 |und sample for t| 000003a0 68 65 20 70 75 6c 73 65 20 67 65 6e 65 72 61 74 |he pulse generat| 000003b0 6f 72 0d 01 7c 10 e3 20 66 25 3d 30 20 b8 20 26 |or..|.. f%=0 . &| 000003c0 33 46 0d 01 86 36 3f 28 73 6f 75 6e 64 5f 73 61 |3F...6?(sound_sa| 000003d0 6d 70 6c 65 25 2b 26 31 30 30 2b 66 25 29 3d 3f |mple%+&100+f%)=?| 000003e0 28 73 6f 75 6e 64 5f 73 61 6d 70 6c 65 25 2b 66 |(sound_sample%+f| 000003f0 25 2a 28 38 2f 34 29 29 0d 01 90 05 ed 0d 01 9a |%*(8/4))........| 00000400 10 e3 20 66 25 3d 30 20 b8 20 26 42 46 0d 01 a4 |.. f%=0 . &BF...| 00000410 3b 3f 28 73 6f 75 6e 64 5f 73 61 6d 70 6c 65 25 |;?(sound_sample%| 00000420 2b 26 31 31 30 2b 66 25 29 3d 3f 28 73 6f 75 6e |+&110+f%)=?(soun| 00000430 64 5f 73 61 6d 70 6c 65 25 2b 26 38 30 2b 66 25 |d_sample%+&80+f%| 00000440 2a 28 38 2f 31 32 29 29 0d 01 ae 05 ed 0d 01 b8 |*(8/12))........| 00000450 1c c8 99 20 22 53 6f 75 6e 64 5f 56 6f 6c 75 6d |... "Sound_Volum| 00000460 65 22 2c 73 63 5f 76 6f 6c 0d 01 c2 22 73 6f 75 |e",sc_vol..."sou| 00000470 6e 64 5f 76 6f 69 63 65 25 3d 63 6f 64 65 2b 21 |nd_voice%=code+!| 00000480 28 63 6f 64 65 2b 32 32 2a 34 29 0d 01 cc 23 21 |(code+22*4)...#!| 00000490 28 73 6f 75 6e 64 5f 76 6f 69 63 65 25 2b 30 29 |(sound_voice%+0)| 000004a0 3d 73 6f 75 6e 64 5f 62 75 66 66 65 72 25 0d 01 |=sound_buffer%..| 000004b0 d6 26 21 28 73 6f 75 6e 64 5f 76 6f 69 63 65 25 |.&!(sound_voice%| 000004c0 2b 34 29 3d 73 6f 75 6e 64 5f 76 6f 6c 5f 74 61 |+4)=sound_vol_ta| 000004d0 62 6c 65 25 0d 01 e0 23 21 28 73 6f 75 6e 64 5f |ble%...#!(sound_| 000004e0 76 6f 69 63 65 25 2b 38 29 3d 73 6f 75 6e 64 5f |voice%+8)=sound_| 000004f0 73 61 6d 70 6c 65 25 0d 01 ea 27 21 28 73 6f 75 |sample%...'!(sou| 00000500 6e 64 5f 76 6f 69 63 65 25 2b 31 32 29 3d 73 6f |nd_voice%+12)=so| 00000510 75 6e 64 5f 73 74 61 63 6b 25 2b 26 34 30 0d 01 |und_stack%+&40..| 00000520 f4 14 73 6f 75 6e 64 5f 76 6f 69 63 65 25 2b 3d |..sound_voice%+=| 00000530 31 36 0d 01 fe 05 e1 0d 02 08 04 0d 02 12 12 dd |16..............| 00000540 f2 73 6f 75 6e 64 5f 72 65 69 6e 69 74 0d 02 1c |.sound_reinit...| 00000550 22 73 6f 75 6e 64 5f 76 6f 69 63 65 25 3d 63 6f |"sound_voice%=co| 00000560 64 65 2b 21 28 63 6f 64 65 2b 32 32 2a 34 29 0d |de+!(code+22*4).| 00000570 02 26 23 21 28 73 6f 75 6e 64 5f 76 6f 69 63 65 |.&#!(sound_voice| 00000580 25 2b 30 29 3d 73 6f 75 6e 64 5f 62 75 66 66 65 |%+0)=sound_buffe| 00000590 72 25 0d 02 30 26 21 28 73 6f 75 6e 64 5f 76 6f |r%..0&!(sound_vo| 000005a0 69 63 65 25 2b 34 29 3d 73 6f 75 6e 64 5f 76 6f |ice%+4)=sound_vo| 000005b0 6c 5f 74 61 62 6c 65 25 0d 02 3a 23 21 28 73 6f |l_table%..:#!(so| 000005c0 75 6e 64 5f 76 6f 69 63 65 25 2b 38 29 3d 73 6f |und_voice%+8)=so| 000005d0 75 6e 64 5f 73 61 6d 70 6c 65 25 0d 02 44 27 21 |und_sample%..D'!| 000005e0 28 73 6f 75 6e 64 5f 76 6f 69 63 65 25 2b 31 32 |(sound_voice%+12| 000005f0 29 3d 73 6f 75 6e 64 5f 73 74 61 63 6b 25 2b 26 |)=sound_stack%+&| 00000600 34 30 0d 02 4e 14 73 6f 75 6e 64 5f 76 6f 69 63 |40..N.sound_voic| 00000610 65 25 2b 3d 31 36 0d 02 58 05 e1 0d 02 62 04 0d |e%+=16..X....b..| 00000620 02 6c 2c f4 20 43 61 6c 6c 20 6a 75 73 74 20 62 |.l,. Call just b| 00000630 65 66 6f 72 65 20 73 74 61 72 74 69 6e 67 20 74 |efore starting t| 00000640 68 65 20 65 6d 75 6c 61 74 6f 72 0d 02 76 12 dd |he emulator..v..| 00000650 20 f2 73 6f 75 6e 64 5f 73 65 74 75 70 0d 02 80 | .sound_setup...| 00000660 0b ea 20 66 25 2c 61 25 0d 02 8a 3f c8 99 20 22 |.. f%,a%...?.. "| 00000670 53 6f 75 6e 64 5f 49 6e 73 74 61 6c 6c 56 6f 69 |Sound_InstallVoi| 00000680 63 65 22 2c 73 6f 75 6e 64 5f 76 6f 69 63 65 25 |ce",sound_voice%| 00000690 2c 30 20 b8 20 2c 73 6f 75 6e 64 5f 76 6f 69 63 |,0 . ,sound_voic| 000006a0 65 5f 73 6c 6f 74 25 0d 02 94 40 c8 99 20 22 53 |e_slot%...@.. "S| 000006b0 6f 75 6e 64 5f 43 6f 6e 66 69 67 75 72 65 22 2c |ound_Configure",| 000006c0 34 2c 32 30 38 2c 34 38 2c 30 2c 30 20 b8 20 73 |4,208,48,0,0 . s| 000006d0 63 5f 30 2c 73 63 5f 31 2c 73 63 5f 32 2c 73 63 |c_0,sc_1,sc_2,sc| 000006e0 5f 33 2c 73 63 5f 34 0d 02 9e 26 c8 99 20 22 53 |_3,sc_4...&.. "S| 000006f0 6f 75 6e 64 5f 41 74 74 61 63 68 56 6f 69 63 65 |ound_AttachVoice| 00000700 22 2c 31 2c 31 20 b8 20 2c 73 76 5f 31 0d 02 a8 |",1,1 . ,sv_1...| 00000710 26 c8 99 20 22 53 6f 75 6e 64 5f 41 74 74 61 63 |&.. "Sound_Attac| 00000720 68 56 6f 69 63 65 22 2c 32 2c 31 20 b8 20 2c 73 |hVoice",2,1 . ,s| 00000730 76 5f 32 0d 02 b2 26 c8 99 20 22 53 6f 75 6e 64 |v_2...&.. "Sound| 00000740 5f 41 74 74 61 63 68 56 6f 69 63 65 22 2c 33 2c |_AttachVoice",3,| 00000750 31 20 b8 20 2c 73 76 5f 33 0d 02 bc 26 c8 99 20 |1 . ,sv_3...&.. | 00000760 22 53 6f 75 6e 64 5f 41 74 74 61 63 68 56 6f 69 |"Sound_AttachVoi| 00000770 63 65 22 2c 34 2c 31 20 b8 20 2c 73 76 5f 34 0d |ce",4,1 . ,sv_4.| 00000780 02 c6 30 c8 99 20 22 53 6f 75 6e 64 5f 41 74 74 |..0.. "Sound_Att| 00000790 61 63 68 4e 61 6d 65 64 56 6f 69 63 65 22 2c 31 |achNamedVoice",1| 000007a0 2c 22 36 35 30 32 45 6d 75 6c 61 74 6f 72 22 0d |,"6502Emulator".| 000007b0 02 d0 30 c8 99 20 22 53 6f 75 6e 64 5f 41 74 74 |..0.. "Sound_Att| 000007c0 61 63 68 4e 61 6d 65 64 56 6f 69 63 65 22 2c 32 |achNamedVoice",2| 000007d0 2c 22 36 35 30 32 45 6d 75 6c 61 74 6f 72 22 0d |,"6502Emulator".| 000007e0 02 da 30 c8 99 20 22 53 6f 75 6e 64 5f 41 74 74 |..0.. "Sound_Att| 000007f0 61 63 68 4e 61 6d 65 64 56 6f 69 63 65 22 2c 33 |achNamedVoice",3| 00000800 2c 22 36 35 30 32 45 6d 75 6c 61 74 6f 72 22 0d |,"6502Emulator".| 00000810 02 e4 30 c8 99 20 22 53 6f 75 6e 64 5f 41 74 74 |..0.. "Sound_Att| 00000820 61 63 68 4e 61 6d 65 64 56 6f 69 63 65 22 2c 34 |achNamedVoice",4| 00000830 2c 22 36 35 30 32 45 6d 75 6c 61 74 6f 72 22 0d |,"6502Emulator".| 00000840 02 ee 3b f4 20 53 74 61 72 74 20 69 6e 66 69 6e |..;. Start infin| 00000850 69 74 65 20 64 75 72 61 74 69 6f 6e 20 6e 6f 74 |ite duration not| 00000860 65 73 20 6f 6e 20 65 61 63 68 20 6f 66 20 74 68 |es on each of th| 00000870 65 20 63 68 61 6e 6e 65 6c 73 0d 02 f8 26 c8 99 |e channels...&..| 00000880 20 22 53 6f 75 6e 64 5f 56 6f 6c 75 6d 65 22 2c | "Sound_Volume",| 00000890 76 6f 6c 75 6d 65 25 20 b8 20 73 63 5f 76 6f 6c |volume% . sc_vol| 000008a0 0d 03 02 30 f4 20 53 65 74 20 75 70 20 74 68 65 |...0. Set up the| 000008b0 20 6c 69 6e 65 61 72 20 74 6f 20 6c 6f 67 20 76 | linear to log v| 000008c0 6f 6c 75 6d 65 20 63 6f 6e 76 65 72 73 69 6f 6e |olume conversion| 000008d0 0d 03 0c 0f e3 20 66 25 3d 30 20 b8 20 26 46 0d |..... f%=0 . &F.| 000008e0 03 16 11 61 25 3d 66 25 2b 28 66 25 3c 3c 34 29 |...a%=f%+(f%<<4)| 000008f0 0d 03 20 11 61 25 3d 61 25 2b 28 61 25 3c 3c 38 |.. .a%=a%+(a%<<8| 00000900 29 0d 03 2a 12 61 25 3d 61 25 2b 28 61 25 3c 3c |)..*.a%=a%+(a%<<| 00000910 31 36 29 0d 03 34 25 c8 99 20 22 53 6f 75 6e 64 |16)..4%.. "Sound| 00000920 5f 53 6f 75 6e 64 4c 6f 67 22 2c 28 61 25 3e 3e |_SoundLog",(a%>>| 00000930 3e 31 29 20 b8 20 61 25 0d 03 3e 0d f4 50 52 49 |>1) . a%..>..PRI| 00000940 4e 54 20 61 25 0d 03 48 1d 3f 28 73 6f 75 6e 64 |NT a%..H.?(sound| 00000950 5f 76 6f 6c 5f 74 61 62 6c 65 25 2b 66 25 29 3d |_vol_table%+f%)=| 00000960 61 25 0d 03 52 05 ed 0d 03 5c 10 d4 20 31 2c 2d |a%..R....\.. 1,-| 00000970 31 2c 31 2c 32 35 35 0d 03 66 10 d4 20 32 2c 2d |1,1,255..f.. 2,-| 00000980 31 2c 31 2c 32 35 35 0d 03 70 10 d4 20 33 2c 2d |1,1,255..p.. 3,-| 00000990 31 2c 31 2c 32 35 35 0d 03 7a 10 d4 20 34 2c 2d |1,1,255..z.. 4,-| 000009a0 31 2c 31 2c 32 35 35 0d 03 84 05 e1 0d 03 8e 04 |1,1,255.........| 000009b0 0d 03 98 25 f4 20 43 61 6c 6c 20 61 66 74 65 72 |...%. Call after| 000009c0 20 65 78 69 74 69 6e 67 20 74 68 65 20 65 6d 75 | exiting the emu| 000009d0 6c 61 74 6f 72 0d 03 a2 14 dd 20 f2 73 6f 75 6e |lator..... .soun| 000009e0 64 5f 72 65 73 74 6f 72 65 0d 03 ac 1c c8 99 20 |d_restore...... | 000009f0 22 53 6f 75 6e 64 5f 56 6f 6c 75 6d 65 22 2c 73 |"Sound_Volume",s| 00000a00 63 5f 76 6f 6c 0d 03 b6 31 c8 99 20 22 53 6f 75 |c_vol...1.. "Sou| 00000a10 6e 64 5f 43 6f 6e 66 69 67 75 72 65 22 2c 73 63 |nd_Configure",sc| 00000a20 5f 30 2c 73 63 5f 31 2c 73 63 5f 32 2c 73 63 5f |_0,sc_1,sc_2,sc_| 00000a30 33 2c 73 63 5f 34 0d 03 c0 21 c8 99 20 22 53 6f |3,sc_4...!.. "So| 00000a40 75 6e 64 5f 41 74 74 61 63 68 56 6f 69 63 65 22 |und_AttachVoice"| 00000a50 2c 31 2c 73 76 5f 31 0d 03 ca 21 c8 99 20 22 53 |,1,sv_1...!.. "S| 00000a60 6f 75 6e 64 5f 41 74 74 61 63 68 56 6f 69 63 65 |ound_AttachVoice| 00000a70 22 2c 32 2c 73 76 5f 32 0d 03 d4 21 c8 99 20 22 |",2,sv_2...!.. "| 00000a80 53 6f 75 6e 64 5f 41 74 74 61 63 68 56 6f 69 63 |Sound_AttachVoic| 00000a90 65 22 2c 33 2c 73 76 5f 33 0d 03 de 21 c8 99 20 |e",3,sv_3...!.. | 00000aa0 22 53 6f 75 6e 64 5f 41 74 74 61 63 68 56 6f 69 |"Sound_AttachVoi| 00000ab0 63 65 22 2c 34 2c 73 76 5f 34 0d 03 e8 2e c8 99 |ce",4,sv_4......| 00000ac0 20 22 53 6f 75 6e 64 5f 52 65 6d 6f 76 65 56 6f | "Sound_RemoveVo| 00000ad0 69 63 65 22 2c 30 2c 73 6f 75 6e 64 5f 76 6f 69 |ice",0,sound_voi| 00000ae0 63 65 5f 73 6c 6f 74 25 0d 03 f2 05 e1 0d 03 fc |ce_slot%........| 00000af0 04 0d 04 06 30 f4 20 43 6f 64 65 20 74 6f 20 69 |....0. Code to i| 00000b00 6e 74 65 72 70 72 65 74 20 77 72 69 74 65 73 20 |nterpret writes | 00000b10 74 6f 20 74 68 65 20 73 6f 75 6e 64 20 63 68 69 |to the sound chi| 00000b20 70 0d 04 10 37 f4 20 6d 65 6d 3d 33 20 41 3d 34 |p...7. mem=3 A=4| 00000b30 20 58 3d 35 20 59 3d 36 20 46 3d 37 20 53 50 3d | X=5 Y=6 F=7 SP=| 00000b40 38 20 74 69 6d 65 3d 39 20 7a 70 63 3d 31 30 20 |8 time=9 zpc=10 | 00000b50 74 61 62 6c 65 3d 31 31 0d 04 1a 0c f4 20 70 3d |table=11..... p=| 00000b60 70 61 73 73 0d 04 24 12 dd 20 a4 73 6f 75 6e 64 |pass..$.. .sound| 00000b70 5f 6c 61 74 63 68 0d 04 2e 11 f2 73 6f 75 6e 64 |_latch.....sound| 00000b80 5f 64 65 66 69 6e 65 0d 04 38 0a 5b 4f 50 54 20 |_define..8.[OPT | 00000b90 70 0d 04 42 04 0d 04 4c 40 3b 20 74 68 65 20 66 |p..B...L@; the f| 00000ba0 6f 6c 6c 6f 77 69 6e 67 20 62 79 74 65 20 73 68 |ollowing byte sh| 00000bb0 6f 75 6c 64 20 62 65 20 77 72 69 74 74 65 6e 20 |ould be written | 00000bc0 62 79 20 72 65 67 62 5f 34 66 20 61 6e 64 20 73 |by regb_4f and s| 00000bd0 68 6f 75 6c 64 0d 04 56 30 3b 20 68 6f 6c 64 20 |hould..V0; hold | 00000be0 61 20 63 6f 70 79 20 6f 66 20 77 68 61 74 27 73 |a copy of what's| 00000bf0 20 6f 6e 20 74 68 65 20 73 6c 6f 77 20 64 61 74 | on the slow dat| 00000c00 61 20 62 75 73 0d 04 60 04 0d 04 6a 16 2e 73 6f |a bus..`...j..so| 00000c10 75 6e 64 5f 64 61 74 61 20 45 51 55 44 20 30 0d |und_data EQUD 0.| 00000c20 04 74 04 0d 04 7e 0c 3b 20 4e 6f 74 65 73 3a 0d |.t...~.; Notes:.| 00000c30 04 88 45 3b 20 43 6c 6f 63 6b 20 69 73 20 32 4d |..E; Clock is 2M| 00000c40 68 7a 2e 20 4f 6e 65 20 62 75 66 66 65 72 20 66 |hz. One buffer f| 00000c50 69 6c 6c 20 65 76 65 72 79 20 34 38 20 6d 69 63 |ill every 48 mic| 00000c60 72 6f 20 73 65 63 73 20 3d 20 39 36 20 63 79 63 |ro secs = 96 cyc| 00000c70 6c 65 73 2e 0d 04 92 43 3b 20 50 69 74 63 68 20 |les....C; Pitch | 00000c80 70 68 61 73 65 20 69 6e 63 72 65 6d 65 6e 74 20 |phase increment | 00000c90 3d 20 26 36 30 30 30 30 20 2f 20 28 31 30 20 62 |= &60000 / (10 b| 00000ca0 69 74 20 42 42 43 20 73 6f 75 6e 64 20 63 68 69 |it BBC sound chi| 00000cb0 70 20 66 72 65 71 29 0d 04 9c 40 3b 20 43 6c 65 |p freq)...@; Cle| 00000cc0 61 72 79 20 67 72 65 61 74 65 73 74 20 73 65 6e |ary greatest sen| 00000cd0 73 69 62 6c 65 20 70 69 74 63 68 20 69 6e 63 72 |sible pitch incr| 00000ce0 65 6d 65 6e 74 20 69 73 20 26 34 30 30 30 2c 20 |ement is &4000, | 00000cf0 73 6f 20 76 65 72 79 0d 04 a6 3b 3b 20 73 6d 61 |so very...;; sma| 00000d00 6c 6c 20 42 42 43 20 66 72 65 71 75 65 6e 63 69 |ll BBC frequenci| 00000d10 65 73 20 61 72 65 20 63 6f 6e 76 65 6e 74 69 6f |es are conventio| 00000d20 6e 61 6c 6c 79 20 6d 65 61 6e 69 6e 67 6c 65 73 |nally meaningles| 00000d30 73 2e 0d 04 b0 2e 3b 20 41 20 42 42 43 20 66 72 |s.....; A BBC fr| 00000d40 65 71 75 65 6e 63 79 20 6f 66 20 31 20 69 73 20 |equency of 1 is | 00000d50 61 73 73 75 6d 65 64 20 74 6f 20 62 65 20 61 6e |assumed to be an| 00000d60 0d 04 ba 3d 3b 20 61 74 74 65 6d 70 74 20 74 6f |...=; attempt to| 00000d70 20 6d 6f 64 75 6c 61 74 65 20 74 68 65 20 61 6d | modulate the am| 00000d80 70 6c 69 74 75 64 65 20 6d 61 6e 75 61 6c 6c 79 |plitude manually| 00000d90 20 28 65 67 20 53 75 70 65 72 69 6f 72 0d 04 c4 | (eg Superior...| 00000da0 32 3b 20 53 6f 66 74 77 61 72 65 20 73 70 65 65 |2; Software spee| 00000db0 63 68 29 20 61 6e 64 20 69 73 20 68 61 6e 64 6c |ch) and is handl| 00000dc0 65 64 20 61 63 63 6f 72 64 69 6e 67 6c 79 2e 0d |ed accordingly..| 00000dd0 04 ce 04 0d 04 d8 32 3b 45 20 43 61 6c 6c 65 64 |......2;E Called| 00000de0 20 77 68 65 6e 20 6c 61 74 63 68 20 77 72 69 74 | when latch writ| 00000df0 65 73 20 74 6f 20 73 6f 75 6e 64 20 67 65 6e 65 |es to sound gene| 00000e00 72 61 74 6f 72 0d 04 e2 41 3b 20 20 73 6f 75 6e |rator...A; soun| 00000e10 64 5f 64 61 74 61 20 63 6f 6e 74 61 69 6e 73 20 |d_data contains | 00000e20 61 20 63 6f 70 79 20 6f 66 20 74 68 65 20 62 79 |a copy of the by| 00000e30 74 65 20 77 72 69 74 74 65 6e 20 74 6f 20 74 68 |te written to th| 00000e40 65 20 73 6c 6f 77 0d 04 ec 0f 3b 20 20 64 61 74 |e slow....; dat| 00000e50 61 20 62 75 73 0d 04 f6 2a 3b 20 20 52 30 3d 76 |a bus...*; R0=v| 00000e60 61 6c 75 65 20 77 72 69 74 74 65 6e 20 74 6f 20 |alue written to | 00000e70 6c 61 74 63 68 20 28 62 30 2d 62 32 3d 30 29 0d |latch (b0-b2=0).| 00000e80 05 00 22 3b 20 20 52 33 3d 42 42 43 20 6d 65 6d |.."; R3=BBC mem| 00000e90 6f 72 79 20 61 64 64 72 65 73 73 20 28 6d 65 6d |ory address (mem| 00000ea0 29 0d 05 0a 33 3b 20 20 52 39 3d 74 69 6d 65 20 |)...3; R9=time | 00000eb0 69 6e 20 63 79 63 6c 65 73 20 75 6e 74 69 6c 20 |in cycles until | 00000ec0 6e 65 78 74 20 63 6c 6f 63 6b 20 69 6e 74 65 72 |next clock inter| 00000ed0 72 75 70 74 0d 05 14 1a 3b 58 20 52 30 2d 52 32 |rupt....;X R0-R2| 00000ee0 2c 52 31 33 20 63 6f 72 72 75 70 74 65 64 0d 05 |,R13 corrupted..| 00000ef0 1e 1b 3b 20 20 45 78 69 74 73 20 76 69 61 20 4d |..; Exits via M| 00000f00 4f 56 20 50 43 2c 52 31 34 0d 05 28 04 0d 05 32 |OV PC,R14..(...2| 00000f10 10 2e 73 6f 75 6e 64 5f 6c 61 74 63 68 0d 05 3c |..sound_latch..<| 00000f20 14 53 54 52 20 6d 65 6d 2c 6d 65 6d 73 74 6f 72 |.STR mem,memstor| 00000f30 65 0d 05 46 10 54 53 54 20 52 30 2c 23 31 3c 3c |e..F.TST R0,#1<<| 00000f40 33 0d 05 50 2e 4d 4f 56 4e 45 20 50 43 2c 52 31 |3..P.MOVNE PC,R1| 00000f50 34 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |4 | 00000f60 20 20 20 3b 20 61 63 74 69 76 65 20 6c 6f 77 0d | ; active low.| 00000f70 05 5a 21 4c 44 52 20 52 31 33 2c 28 73 6f 75 6e |.Z!LDR R13,(soun| 00000f80 64 5f 62 75 66 66 73 5f 61 64 64 72 2b 31 32 29 |d_buffs_addr+12)| 00000f90 0d 05 64 17 53 54 4d 46 44 20 52 31 33 21 2c 7b |..d.STMFD R13!,{| 00000fa0 52 33 2c 52 31 34 7d 0d 05 6e 38 4c 44 52 42 20 |R3,R14}..n8LDRB | 00000fb0 52 30 2c 73 6f 75 6e 64 5f 64 61 74 61 20 20 20 |R0,sound_data | 00000fc0 20 20 20 20 20 20 20 20 20 3b 20 67 65 74 20 74 | ; get t| 00000fd0 68 65 20 62 79 74 65 20 77 72 69 74 74 65 6e 0d |he byte written.| 00000fe0 05 78 10 54 53 54 20 52 30 2c 23 31 3c 3c 37 0d |.x.TST R0,#1<<7.| 00000ff0 05 82 38 42 45 51 20 73 6f 75 6e 64 5f 75 70 64 |..8BEQ sound_upd| 00001000 61 74 65 20 20 20 20 20 20 20 20 20 20 20 20 20 |ate | 00001010 20 3b 20 75 70 64 61 74 65 20 74 68 65 20 66 72 | ; update the fr| 00001020 65 71 75 65 6e 63 79 0d 05 8c 13 4d 4f 56 20 52 |equency....MOV R| 00001030 31 2c 52 30 2c 4c 53 52 23 35 0d 05 96 42 80 20 |1,R0,LSR#5...B. | 00001040 52 31 2c 52 31 2c 23 33 20 20 20 20 20 20 20 20 |R1,R1,#3 | 00001050 20 20 20 20 20 20 20 20 20 20 3b 20 63 68 61 6e | ; chan| 00001060 6e 65 6c 20 6e 75 6d 62 65 72 20 28 30 3d 74 6f |nel number (0=to| 00001070 6e 65 33 20 33 3d 6e 6f 69 73 65 29 0d 05 a0 10 |ne3 3=noise)....| 00001080 54 53 54 20 52 30 2c 23 31 3c 3c 34 0d 05 aa 32 |TST R0,#1<<4...2| 00001090 80 20 52 30 2c 52 30 2c 23 26 30 46 20 20 20 20 |. R0,R0,#&0F | 000010a0 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 64 61 | ; da| 000010b0 74 61 20 69 73 20 69 6e 20 62 30 2d 62 33 0d 05 |ta is in b0-b3..| 000010c0 b4 32 42 4e 45 20 73 6f 75 6e 64 5f 76 6f 6c 75 |.2BNE sound_volu| 000010d0 6d 65 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |me | 000010e0 3b 20 76 6f 6c 75 6d 65 20 63 6f 6e 74 72 6f 6c |; volume control| 000010f0 0d 05 be 32 54 45 51 20 52 31 2c 23 33 20 20 20 |...2TEQ R1,#3 | 00001100 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001110 20 20 3b 20 6e 6f 69 73 65 20 63 68 61 6e 6e 65 | ; noise channe| 00001120 6c 3f 0d 05 c8 3e 53 54 52 4e 45 20 52 31 2c 73 |l?...>STRNE R1,s| 00001130 6f 75 6e 64 5f 63 68 61 6e 6e 65 6c 20 20 20 20 |ound_channel | 00001140 20 20 20 20 3b 20 69 66 20 6e 6f 74 20 73 65 74 | ; if not set| 00001150 20 63 75 72 72 65 6e 74 20 63 68 61 6e 6e 65 6c | current channel| 00001160 0d 05 d2 17 41 44 52 20 52 31 34 2c 73 6f 75 6e |....ADR R14,soun| 00001170 64 5f 66 72 65 71 30 0d 05 dc 3d 4c 44 52 20 52 |d_freq0...=LDR R| 00001180 33 2c 5b 52 31 34 2c 52 31 2c 4c 53 4c 23 32 5d |3,[R14,R1,LSL#2]| 00001190 20 20 20 20 20 20 20 20 20 3b 20 67 65 74 20 74 | ; get t| 000011a0 68 65 20 63 75 72 72 65 6e 74 20 66 72 65 71 75 |he current frequ| 000011b0 65 6e 63 79 0d 05 e6 37 42 49 43 20 52 32 2c 52 |ency...7BIC R2,R| 000011c0 33 2c 23 26 30 46 20 20 20 20 20 20 20 20 20 20 |3,#&0F | 000011d0 20 20 20 20 20 20 3b 20 63 6c 65 61 72 20 62 6f | ; clear bo| 000011e0 74 74 6f 6d 20 34 20 62 69 74 73 0d 05 f0 30 84 |ttom 4 bits...0.| 000011f0 52 20 52 32 2c 52 32 2c 52 30 20 20 20 20 20 20 |R R2,R2,R0 | 00001200 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 6e 65 | ; ne| 00001210 77 20 66 72 65 71 75 65 6e 63 79 0d 05 fa 31 53 |w frequency...1S| 00001220 54 52 20 52 32 2c 5b 52 31 34 2c 52 31 2c 4c 53 |TR R2,[R14,R1,LS| 00001230 4c 23 32 5d 20 20 20 20 20 20 20 20 20 3b 20 6e |L#2] ; n| 00001240 65 77 20 66 72 65 71 75 65 6e 63 79 0d 06 04 15 |ew frequency....| 00001250 42 20 73 6f 75 6e 64 5f 66 72 65 71 75 65 6e 63 |B sound_frequenc| 00001260 79 0d 06 0e 34 2e 73 6f 75 6e 64 5f 75 70 64 61 |y...4.sound_upda| 00001270 74 65 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |te | 00001280 20 20 20 3b 20 75 70 64 61 74 65 20 66 72 65 71 | ; update freq| 00001290 75 65 6e 63 79 0d 06 18 33 4c 44 52 20 52 31 2c |uency...3LDR R1,| 000012a0 73 6f 75 6e 64 5f 63 68 61 6e 6e 65 6c 20 20 20 |sound_channel | 000012b0 20 20 20 20 20 20 20 3b 20 63 75 72 72 65 6e 74 | ; current| 000012c0 20 63 68 61 6e 6e 65 6c 0d 06 22 17 41 44 52 20 | channel..".ADR | 000012d0 52 31 34 2c 73 6f 75 6e 64 5f 66 72 65 71 30 0d |R14,sound_freq0.| 000012e0 06 2c 3d 4c 44 52 20 52 33 2c 5b 52 31 34 2c 52 |.,=LDR R3,[R14,R| 000012f0 31 2c 4c 53 4c 23 32 5d 20 20 20 20 20 20 20 20 |1,LSL#2] | 00001300 20 3b 20 67 65 74 20 74 68 65 20 63 75 72 72 65 | ; get the curre| 00001310 6e 74 20 66 72 65 71 75 65 6e 63 79 0d 06 36 34 |nt frequency..64| 00001320 80 20 52 32 2c 52 33 2c 23 26 30 46 20 20 20 20 |. R2,R3,#&0F | 00001330 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 6c 6f | ; lo| 00001340 6f 73 65 20 74 68 65 20 74 6f 70 20 62 69 74 73 |ose the top bits| 00001350 0d 06 40 34 80 20 52 30 2c 52 30 2c 23 26 33 46 |..@4. R0,R0,#&3F| 00001360 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001370 3b 20 62 34 2d 62 39 20 6f 66 20 66 72 65 71 75 |; b4-b9 of frequ| 00001380 65 6e 63 79 0d 06 4a 3a 84 52 20 52 32 2c 52 32 |ency..J:.R R2,R2| 00001390 2c 52 30 2c 4c 53 4c 23 34 20 20 20 20 20 20 20 |,R0,LSL#4 | 000013a0 20 20 20 20 20 3b 20 61 64 64 20 6e 65 77 20 68 | ; add new h| 000013b0 69 67 68 20 6f 72 64 65 72 20 62 69 74 73 0d 06 |igh order bits..| 000013c0 54 31 53 54 52 20 52 32 2c 5b 52 31 34 2c 52 31 |T1STR R2,[R14,R1| 000013d0 2c 4c 53 4c 23 32 5d 20 20 20 20 20 20 20 20 20 |,LSL#2] | 000013e0 3b 20 6e 65 77 20 66 72 65 71 75 65 6e 63 79 0d |; new frequency.| 000013f0 06 5e 15 42 20 73 6f 75 6e 64 5f 66 72 65 71 75 |.^.B sound_frequ| 00001400 65 6e 63 79 0d 06 68 3e 3b 4e 42 20 6e 6f 74 20 |ency..h>;NB not | 00001410 73 75 72 65 20 77 68 65 74 68 65 72 20 79 6f 75 |sure whether you| 00001420 20 73 68 6f 75 6c 64 20 75 70 64 61 74 65 20 73 | should update s| 00001430 6f 75 6e 64 5f 63 68 61 6e 6e 65 6c 20 68 65 72 |ound_channel her| 00001440 65 3f 0d 06 72 3c 2e 73 6f 75 6e 64 5f 76 6f 6c |e?..r<.sound_vol| 00001450 75 6d 65 20 20 20 20 20 20 20 20 20 20 20 20 20 |ume | 00001460 20 20 20 20 3b 20 52 30 3d 76 6f 6c 75 6d 65 20 | ; R0=volume | 00001470 28 31 35 20 6f 66 66 2d 30 20 6d 61 78 29 0d 06 |(15 off-0 max)..| 00001480 7c 3d 52 53 42 20 52 30 2c 52 30 2c 23 31 35 20 ||=RSB R0,R0,#15 | 00001490 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000014a0 3b 20 6e 65 77 20 76 6f 6c 20 30 3d 6f 66 66 20 |; new vol 0=off | 000014b0 31 35 3d 6d 61 78 20 6e 6f 77 21 0d 06 86 16 41 |15=max now!....A| 000014c0 44 52 20 52 31 34 2c 73 6f 75 6e 64 5f 61 6d 70 |DR R14,sound_amp| 000014d0 30 0d 06 90 2e 4c 44 52 42 20 52 32 2c 5b 52 31 |0....LDRB R2,[R1| 000014e0 34 2c 52 31 5d 20 20 20 20 20 20 20 20 20 20 20 |4,R1] | 000014f0 20 20 20 3b 20 6f 6c 64 20 76 6f 6c 75 6d 65 0d | ; old volume.| 00001500 06 9a 0d 54 45 51 20 52 30 2c 52 32 0d 06 a4 3a |...TEQ R0,R2...:| 00001510 3b 42 45 51 20 73 6f 75 6e 64 5f 6c 61 74 63 68 |;BEQ sound_latch| 00001520 5f 65 6e 64 20 20 20 20 20 20 20 20 20 20 20 3b |_end ;| 00001530 20 76 6f 6c 75 6d 65 20 68 61 73 6e 27 74 20 63 | volume hasn't c| 00001540 68 61 6e 67 65 64 0d 06 ae 38 53 54 52 42 20 52 |hanged...8STRB R| 00001550 30 2c 5b 52 31 34 2c 52 31 5d 20 20 20 20 20 20 |0,[R14,R1] | 00001560 20 20 20 20 20 20 20 20 3b 20 77 72 69 74 65 20 | ; write | 00001570 74 68 65 20 6e 65 77 20 76 6f 6c 75 6d 65 0d 06 |the new volume..| 00001580 b8 0d 54 45 51 20 52 31 2c 23 33 0d 06 c2 38 42 |..TEQ R1,#3...8B| 00001590 45 51 20 73 6f 75 6e 64 5f 6c 61 74 63 68 5f 65 |EQ sound_latch_e| 000015a0 6e 64 20 20 20 20 20 20 20 20 20 20 20 3b 20 69 |nd ; i| 000015b0 67 6e 6f 72 65 20 6e 6f 69 73 65 20 63 68 61 6e |gnore noise chan| 000015c0 6e 65 6c 0d 06 cc 17 41 44 52 20 52 31 34 2c 73 |nel....ADR R14,s| 000015d0 6f 75 6e 64 5f 66 72 65 71 30 0d 06 d6 39 4c 44 |ound_freq0...9LD| 000015e0 52 20 52 30 2c 5b 52 31 34 2c 52 31 2c 4c 53 4c |R R0,[R14,R1,LSL| 000015f0 23 32 5d 20 20 20 20 20 20 20 20 20 3b 20 67 65 |#2] ; ge| 00001600 74 20 66 72 65 71 75 65 6e 63 79 20 73 65 74 74 |t frequency sett| 00001610 69 6e 67 0d 06 e0 0d 54 45 51 20 52 30 2c 23 31 |ing....TEQ R0,#1| 00001620 0d 06 ea 2f 42 4c 45 51 20 6d 61 6b 65 5f 73 6f |.../BLEQ make_so| 00001630 75 6e 64 20 20 20 20 20 20 20 20 20 20 20 20 20 |und | 00001640 20 20 3b 20 69 74 27 73 20 73 70 65 65 63 68 0d | ; it's speech.| 00001650 06 f4 15 42 20 73 6f 75 6e 64 5f 6c 61 74 63 68 |...B sound_latch| 00001660 5f 65 6e 64 0d 06 fe 43 2e 73 6f 75 6e 64 5f 66 |_end...C.sound_f| 00001670 72 65 71 75 65 6e 63 79 20 20 20 20 20 20 20 20 |requency | 00001680 20 20 20 20 20 20 3b 20 52 31 3d 63 68 61 6e 6e | ; R1=chann| 00001690 65 6c 20 52 32 3d 6e 65 77 20 66 72 65 71 20 28 |el R2=new freq (| 000016a0 31 30 20 62 69 74 29 0d 07 08 38 54 45 51 20 52 |10 bit)...8TEQ R| 000016b0 31 2c 23 33 20 20 20 20 20 20 20 20 20 20 20 20 |1,#3 | 000016c0 20 20 20 20 20 20 20 20 20 3b 20 52 33 3d 6f 6c | ; R3=ol| 000016d0 64 20 66 72 65 71 20 28 31 30 20 62 69 74 29 0d |d freq (10 bit).| 000016e0 07 12 3f 42 4c 45 51 20 73 6f 75 6e 64 5f 6e 6f |..?BLEQ sound_no| 000016f0 69 73 65 66 72 65 71 20 20 20 20 20 20 20 20 20 |isefreq | 00001700 20 3b 20 43 6f 6e 76 65 72 74 20 52 32 20 74 6f | ; Convert R2 to| 00001710 20 31 30 20 62 69 74 20 66 6f 72 6d 61 74 0d 07 | 10 bit format..| 00001720 1c 34 54 45 51 20 52 32 2c 23 31 20 20 20 20 20 |.4TEQ R2,#1 | 00001730 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001740 3b 20 63 68 65 63 6b 20 66 6f 72 20 73 70 65 61 |; check for spea| 00001750 63 68 0d 07 26 1a 42 45 51 20 73 6f 75 6e 64 5f |ch..&.BEQ sound_| 00001760 73 70 65 61 63 68 5f 73 74 61 72 74 0d 07 30 0d |speach_start..0.| 00001770 54 45 51 20 52 33 2c 23 31 0d 07 3a 1a 42 4c 45 |TEQ R3,#1..:.BLE| 00001780 51 20 73 6f 75 6e 64 5f 73 70 65 61 63 68 5f 73 |Q sound_speach_s| 00001790 74 6f 70 0d 07 44 12 4d 4f 56 20 52 30 2c 23 26 |top..D.MOV R0,#&| 000017a0 36 30 30 30 30 0d 07 4e 37 53 54 4d 46 44 20 52 |60000..N7STMFD R| 000017b0 31 33 21 2c 7b 52 31 7d 20 20 20 20 20 20 20 20 |13!,{R1} | 000017c0 20 20 20 20 20 20 20 3b 20 73 61 76 65 20 63 68 | ; save ch| 000017d0 61 6e 6e 65 6c 20 6e 75 6d 62 65 72 0d 07 58 2f |annel number..X/| 000017e0 4d 4f 56 20 52 31 2c 52 32 20 20 20 20 20 20 20 |MOV R1,R2 | 000017f0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 00001800 64 65 6e 6f 6d 65 6e 61 74 6f 72 0d 07 62 44 42 |denomenator..bDB| 00001810 4c 20 64 69 76 5f 6d 6f 64 20 20 20 20 20 20 20 |L div_mod | 00001820 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 52 | ; R| 00001830 30 3d 70 69 74 63 68 20 61 63 63 75 6d 75 6c 61 |0=pitch accumula| 00001840 74 6f 72 20 69 6e 63 20 63 6f 72 72 20 52 33 0d |tor inc corr R3.| 00001850 07 6c 3a 4c 44 4d 46 44 20 52 31 33 21 2c 7b 52 |.l:LDMFD R13!,{R| 00001860 31 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |1} | 00001870 20 3b 20 72 65 73 74 6f 72 65 20 63 68 61 6e 6e | ; restore chann| 00001880 65 6c 20 6e 75 6d 62 65 72 0d 07 76 0d 43 4d 50 |el number..v.CMP| 00001890 20 52 30 2c 23 30 0d 07 80 0f 4d 4f 56 4c 45 20 | R0,#0....MOVLE | 000018a0 52 30 2c 23 30 0d 07 8a 11 43 4d 50 20 52 30 2c |R0,#0....CMP R0,| 000018b0 23 26 34 30 30 30 0d 07 94 3a 4d 4f 56 47 45 20 |#&4000...:MOVGE | 000018c0 52 30 2c 23 26 34 30 30 30 20 20 20 20 20 20 20 |R0,#&4000 | 000018d0 20 20 20 20 20 20 20 20 3b 20 52 30 3d 6e 65 77 | ; R0=new| 000018e0 20 70 69 74 63 68 20 69 6e 63 72 65 6d 65 6e 74 | pitch increment| 000018f0 0d 07 9e 18 41 44 52 20 52 31 34 2c 73 6f 75 6e |....ADR R14,soun| 00001900 64 5f 70 69 74 63 68 30 0d 07 a8 19 4c 44 52 20 |d_pitch0....LDR | 00001910 52 32 2c 5b 52 31 34 2c 52 31 2c 4c 53 4c 23 32 |R2,[R14,R1,LSL#2| 00001920 5d 0d 07 b2 14 4d 4f 56 20 52 32 2c 52 32 2c 4c |]....MOV R2,R2,L| 00001930 53 52 23 31 36 0d 07 bc 3e 84 52 20 52 32 2c 52 |SR#16...>.R R2,R| 00001940 30 2c 52 32 2c 4c 53 4c 23 31 36 20 20 20 20 20 |0,R2,LSL#16 | 00001950 20 20 20 20 20 20 3b 20 69 6e 73 74 61 6c 6c 20 | ; install | 00001960 6e 65 77 20 70 69 74 63 68 20 69 6e 63 72 65 6d |new pitch increm| 00001970 65 6e 74 0d 07 c6 19 53 54 52 20 52 32 2c 5b 52 |ent....STR R2,[R| 00001980 31 34 2c 52 31 2c 4c 53 4c 23 32 5d 0d 07 d0 39 |14,R1,LSL#2]...9| 00001990 54 45 51 20 52 31 2c 23 32 20 20 20 20 20 20 20 |TEQ R1,#2 | 000019a0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 000019b0 69 73 20 69 74 20 70 69 74 63 68 20 63 68 61 6e |is it pitch chan| 000019c0 6e 65 6c 20 31 0d 07 da 26 42 4e 45 20 73 6f 75 |nel 1...&BNE sou| 000019d0 6e 64 5f 6c 61 74 63 68 5f 65 6e 64 20 20 20 20 |nd_latch_end | 000019e0 20 20 20 20 20 20 20 3b 20 6e 6f 0d 07 e4 44 4c | ; no...DL| 000019f0 44 52 20 52 30 2c 73 6f 75 6e 64 5f 66 72 65 71 |DR R0,sound_freq| 00001a00 33 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 33 |3 ; 3| 00001a10 20 62 69 74 20 66 72 65 71 20 73 65 74 74 69 6e | bit freq settin| 00001a20 67 20 6f 66 20 6e 6f 69 73 65 20 63 68 61 6e 0d |g of noise chan.| 00001a30 07 ee 0e 80 20 52 30 2c 52 30 2c 23 33 0d 07 f8 |.... R0,R0,#3...| 00001a40 3d 54 45 51 20 52 30 2c 23 33 20 20 20 20 20 20 |=TEQ R0,#3 | 00001a50 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 00001a60 20 69 73 20 69 74 20 62 61 73 65 64 20 6f 6e 20 | is it based on | 00001a70 63 68 61 6e 6e 65 6c 20 31 3f 0d 08 02 26 42 4e |channel 1?...&BN| 00001a80 45 20 73 6f 75 6e 64 5f 6c 61 74 63 68 5f 65 6e |E sound_latch_en| 00001a90 64 20 20 20 20 20 20 20 20 20 20 20 3b 20 6e 6f |d ; no| 00001aa0 0d 08 0c 13 3b 42 4c 20 73 6f 75 6e 64 5f 64 65 |....;BL sound_de| 00001ab0 62 75 67 0d 08 16 2d 4d 4f 56 20 52 31 2c 23 33 |bug...-MOV R1,#3| 00001ac0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001ad0 20 20 20 20 20 3b 20 63 68 61 6e 6e 65 6c 20 30 | ; channel 0| 00001ae0 0d 08 20 3e 4c 44 52 20 52 32 2c 73 6f 75 6e 64 |.. >LDR R2,sound| 00001af0 5f 66 72 65 71 33 20 20 20 20 20 20 20 20 20 20 |_freq3 | 00001b00 20 20 3b 20 63 68 61 6e 6e 65 6c 20 30 20 31 30 | ; channel 0 10| 00001b10 2d 62 69 74 20 66 72 65 71 75 65 6e 63 79 0d 08 |-bit frequency..| 00001b20 2a 42 42 20 73 6f 75 6e 64 5f 66 72 65 71 75 65 |*BB sound_freque| 00001b30 6e 63 79 20 20 20 20 20 20 20 20 20 20 20 20 20 |ncy | 00001b40 3b 20 75 70 64 61 74 65 20 66 72 65 71 75 65 6e |; update frequen| 00001b50 63 79 20 66 6f 72 20 63 68 61 6e 6e 65 6c 20 30 |cy for channel 0| 00001b60 0d 08 34 28 2e 73 6f 75 6e 64 5f 6c 61 74 63 68 |..4(.sound_latch| 00001b70 5f 65 6e 64 20 20 20 20 20 20 20 20 20 20 20 20 |_end | 00001b80 20 20 3b 20 45 58 49 54 0d 08 3e 38 3b 42 4c 20 | ; EXIT..>8;BL | 00001b90 73 6f 75 6e 64 5f 64 65 62 75 67 20 20 20 20 20 |sound_debug | 00001ba0 20 20 20 20 20 20 20 20 20 20 20 3b 20 70 72 69 | ; pri| 00001bb0 6e 74 20 75 70 20 64 65 62 75 67 20 64 61 74 61 |nt up debug data| 00001bc0 0d 08 48 28 4c 44 4d 46 44 20 52 31 33 21 2c 7b |..H(LDMFD R13!,{| 00001bd0 52 33 2c 50 43 7d 20 20 20 20 20 20 20 20 20 20 |R3,PC} | 00001be0 20 20 3b 20 45 58 49 54 0d 08 52 17 2e 73 6f 75 | ; EXIT..R..sou| 00001bf0 6e 64 5f 73 70 65 61 63 68 5f 73 74 61 72 74 0d |nd_speach_start.| 00001c00 08 5c 0d 54 45 51 20 52 33 2c 23 31 0d 08 66 33 |.\.TEQ R3,#1..f3| 00001c10 42 45 51 20 73 6f 75 6e 64 5f 6c 61 74 63 68 5f |BEQ sound_latch_| 00001c20 65 6e 64 20 20 20 20 20 20 20 20 20 20 20 3b 20 |end ; | 00001c30 61 6c 72 65 61 64 79 20 73 74 61 72 74 65 64 0d |already started.| 00001c40 08 70 15 42 4c 20 73 6f 75 6e 64 5f 67 65 74 5f |.p.BL sound_get_| 00001c50 74 69 6d 65 0d 08 7a 16 41 44 52 20 52 30 2c 73 |time..z.ADR R0,s| 00001c60 6f 75 6e 64 5f 74 69 6d 65 30 0d 08 84 42 53 54 |ound_time0...BST| 00001c70 52 20 52 32 2c 5b 52 30 2c 52 31 2c 4c 53 4c 23 |R R2,[R0,R1,LSL#| 00001c80 32 5d 20 20 20 20 20 20 20 20 20 20 3b 20 74 69 |2] ; ti| 00001c90 6d 65 20 74 68 69 73 20 63 68 61 6e 6e 65 6c 20 |me this channel | 00001ca0 6c 61 73 74 20 75 70 64 61 74 65 64 0d 08 8e 0d |last updated....| 00001cb0 54 45 51 20 52 31 2c 23 30 0d 08 98 13 3b 42 4c |TEQ R1,#0....;BL| 00001cc0 45 51 20 6c 6f 67 5f 73 74 61 72 74 0d 08 a2 15 |EQ log_start....| 00001cd0 42 20 73 6f 75 6e 64 5f 6c 61 74 63 68 5f 65 6e |B sound_latch_en| 00001ce0 64 0d 08 ac 04 0d 08 b6 1f 3b 45 20 43 61 6c 6c |d........;E Call| 00001cf0 65 64 20 77 68 65 6e 20 73 70 65 61 63 68 20 73 |ed when speach s| 00001d00 74 6f 70 73 0d 08 c0 12 3b 58 20 43 6f 72 72 75 |tops....;X Corru| 00001d10 70 74 73 20 52 30 0d 08 ca 04 0d 08 d4 16 2e 73 |pts R0.........s| 00001d20 6f 75 6e 64 5f 73 70 65 61 63 68 5f 73 74 6f 70 |ound_speach_stop| 00001d30 0d 08 de 0d 54 45 51 20 52 31 2c 23 30 0d 08 e8 |....TEQ R1,#0...| 00001d40 10 3b 42 45 51 20 6c 6f 67 5f 65 6e 64 0d 08 f2 |.;BEQ log_end...| 00001d50 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 08 fc 04 0d |.MOV PC,R14.....| 00001d60 09 06 0d 2e 6d 65 6d 73 74 6f 72 65 0d 09 10 0a |....memstore....| 00001d70 45 51 55 44 20 30 0d 09 1a 04 0d 09 24 28 3b 45 |EQUD 0......$(;E| 00001d80 20 52 39 3d 45 6d 75 6c 61 74 6f 72 20 74 69 6d | R9=Emulator tim| 00001d90 65 20 27 74 69 6c 6c 20 6e 65 78 74 20 65 76 65 |e 'till next eve| 00001da0 6e 74 0d 09 2e 3b 3b 58 20 52 32 3d 63 75 72 72 |nt...;;X R2=curr| 00001db0 65 6e 74 20 74 69 6d 65 20 6f 6e 20 74 68 65 20 |ent time on the | 00001dc0 73 6f 75 6e 64 20 64 65 63 72 65 6d 65 6e 74 69 |sound decrementi| 00001dd0 6e 67 20 32 4d 48 7a 20 63 6c 6f 63 6b 0d 09 38 |ng 2MHz clock..8| 00001de0 13 3b 20 20 52 30 20 63 6f 72 72 75 70 74 65 64 |.; R0 corrupted| 00001df0 0d 09 42 04 0d 09 4c 13 2e 73 6f 75 6e 64 5f 67 |..B...L..sound_g| 00001e00 65 74 5f 74 69 6d 65 0d 09 56 13 4c 44 52 20 52 |et_time..V.LDR R| 00001e10 30 2c 6d 65 6d 73 74 6f 72 65 0d 09 60 14 4c 44 |0,memstore..`.LD| 00001e20 52 20 52 32 2c 5b 52 30 2c 23 6d 69 6e 5d 0d 09 |R R2,[R0,#min]..| 00001e30 6a 40 53 55 42 20 52 32 2c 52 32 2c 52 39 20 20 |j@SUB R2,R2,R9 | 00001e40 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00001e50 3b 20 74 69 6d 65 20 70 61 73 73 65 64 20 73 69 |; time passed si| 00001e60 6e 63 65 20 6c 61 73 74 20 65 76 65 6e 74 0d 09 |nce last event..| 00001e70 74 1c 4c 44 52 20 52 30 2c 5b 52 30 2c 23 73 6f |t.LDR R0,[R0,#so| 00001e80 75 6e 64 5f 74 69 6d 65 72 5d 0d 09 7e 3e 53 55 |und_timer]..~>SU| 00001e90 42 20 52 32 2c 52 30 2c 52 32 20 20 20 20 20 20 |B R2,R0,R2 | 00001ea0 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 63 75 | ; cu| 00001eb0 72 72 65 6e 74 20 74 69 6d 65 20 28 64 65 63 20 |rrent time (dec | 00001ec0 61 74 20 32 4d 68 7a 29 0d 09 88 0e 4d 4f 56 20 |at 2Mhz)....MOV | 00001ed0 50 43 2c 52 31 34 0d 09 92 04 0d 09 9c 3e 3b 45 |PC,R14.......>;E| 00001ee0 20 56 6f 6c 75 6d 65 20 63 68 61 6e 67 65 64 20 | Volume changed | 00001ef0 28 6e 6f 74 20 6a 75 73 74 20 62 65 65 6e 20 73 |(not just been s| 00001f00 65 74 20 74 6f 20 74 68 65 20 73 61 6d 65 20 76 |et to the same v| 00001f10 61 6c 75 65 21 21 21 29 0d 09 a6 23 3b 20 20 54 |alue!!!)...#; T| 00001f20 68 69 73 20 63 68 61 6e 6e 65 6c 20 69 6e 20 73 |his channel in s| 00001f30 70 65 65 63 68 20 6d 6f 64 65 2e 0d 09 b0 2a 3b |peech mode....*;| 00001f40 20 20 52 32 3d 74 68 65 20 6f 6c 64 20 76 6f 6c | R2=the old vol| 00001f50 75 6d 65 20 62 65 66 6f 72 65 20 74 68 65 20 63 |ume before the c| 00001f60 68 61 6e 67 65 0d 09 ba 2a 3b 20 20 52 31 3d 42 |hange...*; R1=B| 00001f70 42 43 20 63 68 61 6e 6e 65 6c 20 6e 75 6d 62 65 |BC channel numbe| 00001f80 72 20 28 30 2d 33 29 20 52 39 3d 74 69 6d 65 0d |r (0-3) R9=time.| 00001f90 09 c4 34 3b 58 20 42 75 66 66 65 72 20 66 69 6c |..4;X Buffer fil| 00001fa0 6c 65 64 20 66 6f 72 20 6d 61 6e 75 61 6c 20 61 |led for manual a| 00001fb0 6d 70 6c 69 74 75 64 65 20 6d 6f 64 75 6c 61 74 |mplitude modulat| 00001fc0 69 6f 6e 0d 09 ce 13 3b 20 20 52 30 20 63 6f 72 |ion....; R0 cor| 00001fd0 72 75 70 74 65 64 0d 09 d8 04 0d 09 e2 0f 2e 6d |rupted.........m| 00001fe0 61 6b 65 5f 73 6f 75 6e 64 0d 09 ec 1a 53 54 4d |ake_sound....STM| 00001ff0 46 44 20 52 31 33 21 2c 7b 52 31 2d 52 35 2c 52 |FD R13!,{R1-R5,R| 00002000 31 34 7d 0d 09 f6 0f 3b 20 54 45 51 20 52 31 2c |14}....; TEQ R1,| 00002010 23 30 0d 0a 00 1d 3b 20 4c 44 4d 4e 45 46 44 20 |#0....; LDMNEFD | 00002020 52 31 33 21 2c 7b 52 31 2d 52 35 2c 50 43 7d 0d |R13!,{R1-R5,PC}.| 00002030 0a 0a 18 3b 20 4c 44 52 42 20 52 30 2c 5b 6d 65 |...; LDRB R0,[me| 00002040 6d 2c 23 26 36 37 5d 0d 0a 14 19 3b 20 4c 44 52 |m,#&67]....; LDR| 00002050 42 20 52 31 34 2c 5b 6d 65 6d 2c 23 26 36 38 5d |B R14,[mem,#&68]| 00002060 0d 0a 1e 19 3b 20 41 44 44 20 52 30 2c 52 30 2c |....; ADD R0,R0,| 00002070 52 31 34 2c 4c 53 4c 23 38 0d 0a 28 1c 3b 20 4c |R14,LSL#8..(.; L| 00002080 44 52 42 20 52 31 34 2c 5b 52 30 2c 59 2c 4c 53 |DRB R14,[R0,Y,LS| 00002090 52 23 32 34 5d 0d 0a 32 11 3b 20 41 44 44 20 52 |R#24]..2.; ADD R| 000020a0 30 2c 52 30 2c 59 0d 0a 3c 1a 3b 20 41 44 44 20 |0,R0,Y..<.; ADD | 000020b0 52 30 2c 52 30 2c 52 31 34 2c 4c 53 4c 23 31 36 |R0,R0,R14,LSL#16| 000020c0 0d 0a 46 17 3b 20 4c 44 52 20 52 30 2c 5b 6d 65 |..F.; LDR R0,[me| 000020d0 6d 2c 23 26 36 30 5d 0d 0a 50 11 3b 20 42 4c 20 |m,#&60]..P.; BL | 000020e0 6c 6f 67 5f 77 6f 72 64 0d 0a 5a 0f 3b 20 4d 4f |log_word..Z.; MO| 000020f0 56 20 52 30 2c 52 32 0d 0a 64 11 3b 20 42 4c 20 |V R0,R2..d.; BL | 00002100 6c 6f 67 5f 77 6f 72 64 0d 0a 6e 32 4d 4f 56 20 |log_word..n2MOV | 00002110 52 34 2c 52 32 2c 4c 53 4c 23 31 20 20 20 20 20 |R4,R2,LSL#1 | 00002120 20 20 20 20 20 20 20 20 20 20 3b 20 61 6d 70 6c | ; ampl| 00002130 69 74 75 64 65 20 30 2d 33 30 0d 0a 78 37 53 55 |itude 0-30..x7SU| 00002140 42 53 20 52 34 2c 52 34 2c 23 31 35 20 20 20 20 |BS R4,R4,#15 | 00002150 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 61 6d | ; am| 00002160 70 6c 69 74 75 64 65 20 2d 31 35 20 74 6f 20 31 |plitude -15 to 1| 00002170 35 0d 0a 82 0f 4d 4f 56 50 4c 20 52 30 2c 23 30 |5....MOVPL R0,#0| 00002180 0d 0a 8c 2c 4d 4f 56 4d 49 20 52 30 2c 23 31 20 |...,MOVMI R0,#1 | 00002190 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000021a0 20 20 3b 20 73 69 67 6e 20 62 69 74 0d 0a 96 32 | ; sign bit...2| 000021b0 52 53 42 4d 49 20 52 34 2c 52 34 2c 23 30 20 20 |RSBMI R4,R4,#0 | 000021c0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 000021d0 6e 6f 77 20 2b 76 65 20 28 31 2d 31 35 29 0d 0a |now +ve (1-15)..| 000021e0 a0 31 4c 44 52 20 52 31 34 2c 28 73 6f 75 6e 64 |.1LDR R14,(sound| 000021f0 5f 62 75 66 66 73 5f 61 64 64 72 2b 34 29 20 20 |_buffs_addr+4) | 00002200 3b 20 6c 6f 67 20 61 6d 70 20 74 61 62 6c 65 0d |; log amp table.| 00002210 0a aa 2c 4c 44 52 42 20 52 34 2c 5b 52 31 34 2c |..,LDRB R4,[R14,| 00002220 52 34 5d 20 20 20 20 20 20 20 20 20 20 20 20 20 |R4] | 00002230 20 3b 20 56 49 44 43 20 61 6d 70 0d 0a b4 3c 82 | ; VIDC amp...<.| 00002240 20 52 34 2c 52 34 2c 52 30 20 20 20 20 20 20 20 | R4,R4,R0 | 00002250 20 20 20 20 20 20 20 20 20 20 20 3b 20 62 75 6e | ; bun| 00002260 67 20 69 6e 20 73 69 67 6e 20 74 6f 20 67 65 74 |g in sign to get| 00002270 20 73 61 6d 70 6c 65 0d 0a be 33 42 4c 20 73 6f | sample...3BL so| 00002280 75 6e 64 5f 67 65 74 5f 74 69 6d 65 20 20 20 20 |und_get_time | 00002290 20 20 20 20 20 20 20 20 20 3b 20 52 32 3d 63 75 | ; R2=cu| 000022a0 72 72 65 6e 74 20 74 69 6d 65 0d 0a c8 17 41 44 |rrent time....AD| 000022b0 52 20 52 31 34 2c 73 6f 75 6e 64 5f 74 69 6d 65 |R R14,sound_time| 000022c0 30 0d 0a d2 42 4c 44 52 20 52 33 2c 5b 52 31 34 |0...BLDR R3,[R14| 000022d0 2c 52 31 2c 4c 53 4c 23 32 5d 20 20 20 20 20 20 |,R1,LSL#2] | 000022e0 20 20 20 3b 20 74 69 6d 65 20 74 68 69 73 20 63 | ; time this c| 000022f0 68 61 6e 6e 65 6c 20 6c 61 73 74 20 75 70 64 61 |hannel last upda| 00002300 74 65 64 0d 0a dc 41 53 55 42 53 20 52 30 2c 52 |ted...ASUBS R0,R| 00002310 33 2c 52 32 20 20 20 20 20 20 20 20 20 20 20 20 |3,R2 | 00002320 20 20 20 20 20 3b 20 74 69 6d 65 20 70 61 73 73 | ; time pass| 00002330 65 64 20 73 69 6e 63 65 20 6c 61 73 74 20 75 70 |ed since last up| 00002340 64 61 74 65 0d 0a e6 39 4d 4f 56 4d 49 20 52 33 |date...9MOVMI R3| 00002350 2c 52 32 20 20 20 20 20 20 20 20 20 20 20 20 20 |,R2 | 00002360 20 20 20 20 20 20 3b 20 63 6c 69 70 20 69 66 20 | ; clip if | 00002370 67 6f 6e 65 20 6e 65 67 61 74 69 76 65 0d 0a f0 |gone negative...| 00002380 41 43 4d 50 20 52 30 2c 23 26 43 30 30 30 20 20 |ACMP R0,#&C000 | 00002390 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 000023a0 20 67 72 65 61 74 65 72 20 74 68 61 6e 20 6f 6e | greater than on| 000023b0 65 20 62 75 66 66 65 72 20 66 69 6c 6c 3f 0d 0a |e buffer fill?..| 000023c0 fa 2e 41 44 44 47 45 20 52 33 2c 52 32 2c 23 26 |..ADDGE R3,R2,#&| 000023d0 43 30 30 30 20 20 20 20 20 20 20 20 20 20 20 20 |C000 | 000023e0 3b 20 63 6c 69 70 20 69 66 20 73 6f 0d 0b 04 11 |; clip if so....| 000023f0 3b 20 42 4c 20 6c 6f 67 5f 77 6f 72 64 0d 0b 0e |; BL log_word...| 00002400 19 41 44 52 20 52 31 34 2c 73 6f 75 6e 64 5f 66 |.ADR R14,sound_f| 00002410 69 6c 6c 65 64 30 0d 0b 18 40 4c 44 52 20 52 35 |illed0...@LDR R5| 00002420 2c 5b 52 31 34 2c 52 31 2c 4c 53 4c 23 32 5d 20 |,[R14,R1,LSL#2] | 00002430 20 20 20 20 20 20 20 20 3b 20 63 75 72 72 65 6e | ; curren| 00002440 74 20 6f 66 66 73 65 74 20 69 6e 20 74 68 65 20 |t offset in the | 00002450 62 75 66 66 65 72 0d 0b 22 11 2e 6d 61 6b 65 5f |buffer.."..make_| 00002460 73 6f 75 6e 64 5f 31 0d 0b 2c 17 41 44 52 20 52 |sound_1..,.ADR R| 00002470 31 34 2c 73 6f 75 6e 64 5f 72 65 61 64 30 0d 0b |14,sound_read0..| 00002480 36 32 4c 44 52 20 52 30 2c 5b 52 31 34 2c 52 31 |62LDR R0,[R14,R1| 00002490 2c 4c 53 4c 23 32 5d 20 20 20 20 20 20 20 20 20 |,LSL#2] | 000024a0 3b 20 61 6d 6f 75 6e 74 20 72 65 61 64 20 74 6f |; amount read to| 000024b0 0d 0b 40 11 53 55 42 53 20 52 30 2c 52 35 2c 52 |..@.SUBS R0,R5,R| 000024c0 30 0d 0b 4a 38 41 44 44 4d 49 20 52 30 2c 52 30 |0..J8ADDMI R0,R0| 000024d0 2c 23 73 6f 75 6e 64 5f 62 75 66 5f 73 69 7a 65 |,#sound_buf_size| 000024e0 25 20 20 3b 20 61 6d 6f 75 6e 74 20 69 6e 20 74 |% ; amount in t| 000024f0 68 65 20 62 75 66 66 65 72 0d 0b 54 0f 43 4d 50 |he buffer..T.CMP| 00002500 20 52 30 2c 23 35 31 32 0d 0b 5e 3f 42 47 54 20 | R0,#512..^?BGT | 00002510 6d 61 6b 65 5f 73 6f 75 6e 64 5f 31 20 20 20 20 |make_sound_1 | 00002520 20 20 20 20 20 20 20 20 20 20 3b 20 77 61 69 74 | ; wait| 00002530 20 66 6f 72 20 6f 75 74 70 75 74 20 74 6f 20 63 | for output to c| 00002540 61 74 63 68 20 75 70 0d 0b 68 1b 4c 44 52 20 52 |atch up..h.LDR R| 00002550 30 2c 73 6f 75 6e 64 5f 62 75 66 66 73 5f 61 64 |0,sound_buffs_ad| 00002560 64 72 0d 0b 72 3c 41 44 44 20 52 30 2c 52 30 2c |dr..r<ADD R0,R0,| 00002570 52 31 2c 4c 53 4c 23 73 6f 75 6e 64 5f 62 75 66 |R1,LSL#sound_buf| 00002580 5f 73 69 7a 65 5f 6c 6f 67 25 20 3b 20 61 64 64 |_size_log% ; add| 00002590 72 65 73 73 20 6f 66 20 62 75 66 66 65 72 0d 0b |ress of buffer..| 000025a0 7c 11 2e 6d 61 6b 65 5f 73 6f 75 6e 64 5f 32 0d ||..make_sound_2.| 000025b0 0b 86 3b 53 55 42 20 52 33 2c 52 33 2c 23 39 36 |..;SUB R3,R3,#96| 000025c0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000025d0 20 3b 20 74 72 79 20 61 6e 64 20 64 6f 20 61 6e | ; try and do an| 000025e0 6f 74 68 65 72 20 62 79 74 65 0d 0b 90 0d 43 4d |other byte....CM| 000025f0 50 20 52 33 2c 52 32 0d 0b 9a 29 42 4c 54 20 6d |P R3,R2...)BLT m| 00002600 61 6b 65 5f 73 6f 75 6e 64 5f 33 20 20 20 20 20 |ake_sound_3 | 00002610 20 20 20 20 20 20 20 20 20 3b 20 63 61 6e 27 74 | ; can't| 00002620 0d 0b a4 34 53 54 52 42 20 52 34 2c 5b 52 30 2c |...4STRB R4,[R0,| 00002630 52 35 5d 20 20 20 20 20 20 20 20 20 20 20 20 20 |R5] | 00002640 20 20 3b 20 77 72 69 74 65 20 6f 75 74 20 61 20 | ; write out a | 00002650 62 79 74 65 0d 0b ae 15 3b 20 53 54 4d 46 44 20 |byte....; STMFD | 00002660 52 31 33 21 2c 7b 52 30 7d 0d 0b b8 0f 3b 20 4d |R13!,{R0}....; M| 00002670 4f 56 20 52 30 2c 52 34 0d 0b c2 11 3b 20 42 4c |OV R0,R4....; BL| 00002680 20 6c 6f 67 5f 77 6f 72 64 0d 0b cc 15 3b 20 4c | log_word....; L| 00002690 44 4d 46 44 20 52 31 33 21 2c 7b 52 30 7d 0d 0b |DMFD R13!,{R0}..| 000026a0 d6 10 41 44 44 20 52 35 2c 52 35 2c 23 31 0d 0b |..ADD R5,R5,#1..| 000026b0 e0 1b 43 4d 50 20 52 35 2c 23 73 6f 75 6e 64 5f |..CMP R5,#sound_| 000026c0 62 75 66 5f 73 69 7a 65 25 0d 0b ea 36 4d 4f 56 |buf_size%...6MOV| 000026d0 47 45 20 52 35 2c 23 30 20 20 20 20 20 20 20 20 |GE R5,#0 | 000026e0 20 20 20 20 20 20 20 20 20 20 20 3b 20 77 72 61 | ; wra| 000026f0 70 20 62 75 66 66 65 72 20 6f 66 66 73 65 74 0d |p buffer offset.| 00002700 0b f4 12 42 20 6d 61 6b 65 5f 73 6f 75 6e 64 5f |...B make_sound_| 00002710 32 0d 0b fe 11 2e 6d 61 6b 65 5f 73 6f 75 6e 64 |2.....make_sound| 00002720 5f 33 0d 0c 08 11 41 44 44 20 52 33 2c 52 33 2c |_3....ADD R3,R3,| 00002730 23 39 36 0d 0c 12 19 41 44 52 20 52 31 34 2c 73 |#96....ADR R14,s| 00002740 6f 75 6e 64 5f 66 69 6c 6c 65 64 30 0d 0c 1c 35 |ound_filled0...5| 00002750 53 54 52 20 52 35 2c 5b 52 31 34 2c 52 31 2c 4c |STR R5,[R14,R1,L| 00002760 53 4c 23 32 5d 20 20 20 20 20 20 20 20 20 3b 20 |SL#2] ; | 00002770 6e 65 77 20 62 75 66 66 65 72 20 6f 66 66 73 65 |new buffer offse| 00002780 74 0d 0c 26 17 41 44 52 20 52 31 34 2c 73 6f 75 |t..&.ADR R14,sou| 00002790 6e 64 5f 74 69 6d 65 30 0d 0c 30 39 53 54 52 20 |nd_time0..09STR | 000027a0 52 33 2c 5b 52 31 34 2c 52 31 2c 4c 53 4c 23 32 |R3,[R14,R1,LSL#2| 000027b0 5d 20 20 20 20 20 20 20 20 20 3b 20 6e 65 77 20 |] ; new | 000027c0 74 69 6d 65 20 6c 61 73 74 20 75 70 64 61 74 65 |time last update| 000027d0 64 0d 0c 3a 19 4c 44 4d 46 44 20 52 31 33 21 2c |d..:.LDMFD R13!,| 000027e0 7b 52 31 2d 52 35 2c 50 43 7d 0d 0c 44 04 0d 0c |{R1-R5,PC}..D...| 000027f0 4e 2e 3b 45 20 52 32 3d 6e 6f 69 73 65 20 63 68 |N.;E R2=noise ch| 00002800 61 6e 6e 65 6c 20 66 72 65 71 75 65 6e 63 79 20 |annel frequency | 00002810 28 62 62 63 20 66 6f 72 6d 61 74 29 0d 0c 58 2a |(bbc format)..X*| 00002820 3b 58 20 52 32 3d 6e 6f 69 73 65 20 63 68 61 6e |;X R2=noise chan| 00002830 6e 65 6c 20 66 72 65 71 75 6e 65 63 79 20 28 31 |nel frequnecy (1| 00002840 30 20 62 69 74 29 0d 0c 62 12 3b 20 20 43 6f 72 |0 bit)..b.; Cor| 00002850 72 75 70 74 73 20 52 30 0d 0c 6c 3d 3b 20 20 44 |rupts R0..l=; D| 00002860 6f 6e 27 74 20 6e 65 65 64 20 74 6f 20 63 6c 69 |on't need to cli| 00002870 70 20 73 69 6e 63 65 20 70 69 74 63 68 20 69 6e |p since pitch in| 00002880 63 20 63 61 6e 20 67 6f 20 75 70 20 74 6f 20 26 |c can go up to &| 00002890 36 30 30 30 30 0d 0c 76 04 0d 0c 80 14 2e 73 6f |60000..v......so| 000028a0 75 6e 64 5f 6e 6f 69 73 65 66 72 65 71 0d 0c 8a |und_noisefreq...| 000028b0 0e 80 20 52 30 2c 52 32 2c 23 33 0d 0c 94 0d 54 |.. R0,R2,#3....T| 000028c0 45 51 20 52 30 2c 23 33 0d 0c 9e 16 42 45 51 20 |EQ R0,#3....BEQ | 000028d0 73 6f 75 6e 64 5f 75 73 65 66 72 65 71 32 0d 0c |sound_usefreq2..| 000028e0 a8 2c 80 20 52 30 2c 52 32 2c 23 37 20 20 20 20 |.,. R0,R2,#7 | 000028f0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 00002900 46 42 20 4e 46 31 20 4e 46 30 0d 0c b2 19 41 44 |FB NF1 NF0....AD| 00002910 52 20 52 32 2c 73 6f 75 6e 64 5f 6e 6f 69 73 65 |R R2,sound_noise| 00002920 74 61 62 0d 0c bc 18 4c 44 52 20 52 32 2c 5b 52 |tab....LDR R2,[R| 00002930 32 2c 52 30 2c 4c 53 4c 23 32 5d 0d 0c c6 0e 4d |2,R0,LSL#2]....M| 00002940 4f 56 20 50 43 2c 52 31 34 0d 0c d0 13 2e 73 6f |OV PC,R14.....so| 00002950 75 6e 64 5f 75 73 65 66 72 65 71 32 0d 0c da 0d |und_usefreq2....| 00002960 54 53 54 20 52 32 2c 23 34 0d 0c e4 42 4c 44 52 |TST R2,#4...BLDR| 00002970 20 52 32 2c 73 6f 75 6e 64 5f 66 72 65 71 32 20 | R2,sound_freq2 | 00002980 20 20 20 20 20 20 20 20 20 20 20 3b 20 75 73 65 | ; use| 00002990 20 74 6f 6e 65 20 67 65 6e 65 72 61 74 6f 72 20 | tone generator | 000029a0 31 20 66 72 65 71 75 65 6e 63 79 0d 0c ee 3b 3b |1 frequency...;;| 000029b0 ec 51 20 52 32 2c 52 32 2c 4c 53 4c 23 34 20 20 |.Q R2,R2,LSL#4 | 000029c0 20 20 20 20 20 20 20 20 20 20 20 3b 20 6d 75 6c | ; mul| 000029d0 74 69 70 6c 79 20 69 66 20 70 75 6c 73 65 20 63 |tiply if pulse c| 000029e0 68 61 6e 6e 65 6c 0d 0c f8 3c 3b 4d 4f 56 4e 45 |hannel...<;MOVNE| 000029f0 20 52 32 2c 52 32 2c 4c 53 52 23 32 20 20 20 20 | R2,R2,LSR#2 | 00002a00 20 20 20 20 20 20 20 20 20 3b 20 64 69 76 69 64 | ; divid| 00002a10 65 20 69 66 20 6e 6f 69 73 65 20 63 68 61 6e 6e |e if noise chann| 00002a20 65 6c 0d 0c f9 04 0d 0c fa 34 4d 4f 56 20 52 32 |el.......4MOV R2| 00002a30 2c 52 32 2c 4c 53 4c 23 34 20 20 20 20 20 20 20 |,R2,LSL#4 | 00002a40 20 20 20 20 20 20 20 3b 20 63 68 61 6e 67 65 64 | ; changed| 00002a50 20 31 31 2f 39 36 20 4d 52 42 0d 0c fb 04 0d 0d | 11/96 MRB......| 00002a60 2a 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 0d 34 13 |*.MOV PC,R14..4.| 00002a70 2e 73 6f 75 6e 64 5f 6e 6f 69 73 65 74 61 62 0d |.sound_noisetab.| 00002a80 0d 3e 2e 45 51 55 44 20 26 46 31 20 20 20 20 20 |.>.EQUD &F1 | 00002a90 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00002aa0 20 3b 20 70 75 6c 73 65 20 68 69 67 68 0d 0d 48 | ; pulse high..H| 00002ab0 2d 45 51 55 44 20 26 31 44 35 20 20 20 20 20 20 |-EQUD &1D5 | 00002ac0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 00002ad0 20 70 75 6c 73 65 20 6d 65 64 0d 0d 52 2d 45 51 | pulse med..R-EQ| 00002ae0 55 44 20 26 33 43 36 20 20 20 20 20 20 20 20 20 |UD &3C6 | 00002af0 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 70 75 | ; pu| 00002b00 6c 73 65 20 6c 6f 77 0d 0d 5c 0a 45 51 55 44 20 |lse low..\.EQUD | 00002b10 30 0d 0d 66 2e 45 51 55 44 20 26 31 46 20 20 20 |0..f.EQUD &1F | 00002b20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00002b30 20 20 20 3b 20 6e 6f 69 73 65 20 68 69 67 68 0d | ; noise high.| 00002b40 0d 70 2d 45 51 55 44 20 26 41 33 20 20 20 20 20 |.p-EQUD &A3 | 00002b50 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00002b60 20 3b 20 6e 6f 69 73 65 20 6d 65 64 0d 0d 7a 2d | ; noise med..z-| 00002b70 45 51 55 44 20 26 31 30 30 20 20 20 20 20 20 20 |EQUD &100 | 00002b80 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 00002b90 6e 6f 69 73 65 20 6c 6f 77 0d 0d 84 0a 45 51 55 |noise low....EQU| 00002ba0 44 20 30 0d 0d 8e 04 0d 0d 98 3e 2e 73 6f 75 6e |D 0.......>.soun| 00002bb0 64 5f 63 68 61 6e 6e 65 6c 20 20 20 20 20 20 45 |d_channel E| 00002bc0 51 55 44 20 30 20 20 20 20 3b 20 63 75 72 72 65 |QUD 0 ; curre| 00002bd0 6e 74 20 6e 6f 74 65 20 63 68 61 6e 6e 65 6c 20 |nt note channel | 00002be0 28 30 2d 32 29 0d 0d a2 43 2e 73 6f 75 6e 64 5f |(0-2)...C.sound_| 00002bf0 66 72 65 71 30 20 20 20 20 20 20 20 20 45 51 55 |freq0 EQU| 00002c00 44 20 30 20 20 20 20 3b 20 66 72 65 71 75 65 6e |D 0 ; frequen| 00002c10 63 79 20 6f 66 20 63 68 61 6e 6e 65 6c 20 33 20 |cy of channel 3 | 00002c20 28 31 30 20 62 69 74 29 0d 0d ac 3a 2e 73 6f 75 |(10 bit)...:.sou| 00002c30 6e 64 5f 66 72 65 71 31 20 20 20 20 20 20 20 20 |nd_freq1 | 00002c40 45 51 55 44 20 30 20 20 20 20 3b 20 66 72 65 71 |EQUD 0 ; freq| 00002c50 75 65 6e 63 79 20 6f 66 20 63 68 61 6e 6e 65 6c |uency of channel| 00002c60 20 32 0d 0d b6 3a 2e 73 6f 75 6e 64 5f 66 72 65 | 2...:.sound_fre| 00002c70 71 32 20 20 20 20 20 20 20 20 45 51 55 44 20 30 |q2 EQUD 0| 00002c80 20 20 20 20 3b 20 66 72 65 71 75 65 6e 63 79 20 | ; frequency | 00002c90 6f 66 20 63 68 61 6e 6e 65 6c 20 31 0d 0d c0 45 |of channel 1...E| 00002ca0 2e 73 6f 75 6e 64 5f 66 72 65 71 33 20 20 20 20 |.sound_freq3 | 00002cb0 20 20 20 20 45 51 55 44 20 30 20 20 20 20 3b 20 | EQUD 0 ; | 00002cc0 66 72 65 71 75 65 6e 63 79 20 6f 66 20 63 68 61 |frequency of cha| 00002cd0 6e 6e 65 6c 20 30 20 58 20 46 42 20 4e 46 31 2c |nnel 0 X FB NF1,| 00002ce0 30 0d 0d ca 3f 2e 73 6f 75 6e 64 5f 61 6d 70 30 |0...?.sound_amp0| 00002cf0 20 20 20 20 20 20 20 20 20 45 51 55 42 20 30 20 | EQUB 0 | 00002d00 20 20 20 3b 20 61 6d 70 6c 69 74 75 64 65 20 6f | ; amplitude o| 00002d10 66 20 63 68 61 6e 6e 65 6c 20 33 20 30 2d 31 35 |f channel 3 0-15| 00002d20 0d 0d d4 3a 2e 73 6f 75 6e 64 5f 61 6d 70 31 20 |...:.sound_amp1 | 00002d30 20 20 20 20 20 20 20 20 45 51 55 42 20 30 20 20 | EQUB 0 | 00002d40 20 20 3b 20 61 6d 70 6c 69 74 75 64 65 20 6f 66 | ; amplitude of| 00002d50 20 63 68 61 6e 6e 65 6c 20 32 0d 0d de 3a 2e 73 | channel 2...:.s| 00002d60 6f 75 6e 64 5f 61 6d 70 32 20 20 20 20 20 20 20 |ound_amp2 | 00002d70 20 20 45 51 55 42 20 30 20 20 20 20 3b 20 61 6d | EQUB 0 ; am| 00002d80 70 6c 69 74 75 64 65 20 6f 66 20 63 68 61 6e 6e |plitude of chann| 00002d90 65 6c 20 31 0d 0d e8 3a 2e 73 6f 75 6e 64 5f 61 |el 1...:.sound_a| 00002da0 6d 70 33 20 20 20 20 20 20 20 20 20 45 51 55 42 |mp3 EQUB| 00002db0 20 30 20 20 20 20 3b 20 61 6d 70 6c 69 74 75 64 | 0 ; amplitud| 00002dc0 65 20 6f 66 20 63 68 61 6e 6e 65 6c 20 30 0d 0d |e of channel 0..| 00002dd0 f2 40 2e 73 6f 75 6e 64 5f 72 65 61 64 30 20 20 |.@.sound_read0 | 00002de0 20 20 20 20 20 20 45 51 55 44 20 30 20 20 20 20 | EQUD 0 | 00002df0 3b 20 6f 66 66 73 65 74 20 69 6e 20 62 75 66 66 |; offset in buff| 00002e00 65 72 20 6f 66 20 73 74 61 72 74 20 6f 66 0d 0d |er of start of..| 00002e10 fc 2f 2e 73 6f 75 6e 64 5f 72 65 61 64 31 20 20 |./.sound_read1 | 00002e20 20 20 20 20 20 20 45 51 55 44 20 30 20 20 20 20 | EQUD 0 | 00002e30 3b 20 75 6e 72 65 61 64 20 64 61 74 61 0d 0e 06 |; unread data...| 00002e40 30 2e 73 6f 75 6e 64 5f 72 65 61 64 32 20 20 20 |0.sound_read2 | 00002e50 20 20 20 20 20 45 51 55 44 20 30 20 20 20 20 3b | EQUD 0 ;| 00002e60 20 63 68 61 6e 6e 65 6c 73 20 30 2d 33 0d 0e 10 | channels 0-3...| 00002e70 23 2e 73 6f 75 6e 64 5f 72 65 61 64 33 20 20 20 |#.sound_read3 | 00002e80 20 20 20 20 20 45 51 55 44 20 30 20 20 20 20 3b | EQUD 0 ;| 00002e90 0d 0e 1a 43 2e 73 6f 75 6e 64 5f 66 69 6c 6c 65 |...C.sound_fille| 00002ea0 64 30 20 20 20 20 20 20 45 51 55 44 20 30 20 20 |d0 EQUD 0 | 00002eb0 20 20 3b 20 6f 66 66 73 65 74 20 69 6e 20 62 75 | ; offset in bu| 00002ec0 66 20 66 69 6c 6c 65 64 20 74 6f 20 63 68 61 6e |f filled to chan| 00002ed0 6e 20 30 0d 0e 24 43 2e 73 6f 75 6e 64 5f 66 69 |n 0..$C.sound_fi| 00002ee0 6c 6c 65 64 31 20 20 20 20 20 20 45 51 55 44 20 |lled1 EQUD | 00002ef0 30 20 20 20 20 3b 20 6f 66 66 73 65 74 20 69 6e |0 ; offset in| 00002f00 20 62 75 66 20 66 69 6c 6c 65 64 20 74 6f 20 63 | buf filled to c| 00002f10 68 61 6e 6e 20 31 0d 0e 2e 43 2e 73 6f 75 6e 64 |hann 1...C.sound| 00002f20 5f 66 69 6c 6c 65 64 32 20 20 20 20 20 20 45 51 |_filled2 EQ| 00002f30 55 44 20 30 20 20 20 20 3b 20 6f 66 66 73 65 74 |UD 0 ; offset| 00002f40 20 69 6e 20 62 75 66 20 66 69 6c 6c 65 64 20 74 | in buf filled t| 00002f50 6f 20 63 68 61 6e 6e 20 32 0d 0e 38 43 2e 73 6f |o chann 2..8C.so| 00002f60 75 6e 64 5f 66 69 6c 6c 65 64 33 20 20 20 20 20 |und_filled3 | 00002f70 20 45 51 55 44 20 30 20 20 20 20 3b 20 6f 66 66 | EQUD 0 ; off| 00002f80 73 65 74 20 69 6e 20 62 75 66 20 66 69 6c 6c 65 |set in buf fille| 00002f90 64 20 74 6f 20 63 68 61 6e 6e 20 33 0d 0e 42 39 |d to chann 3..B9| 00002fa0 2e 73 6f 75 6e 64 5f 70 69 74 63 68 30 20 20 20 |.sound_pitch0 | 00002fb0 20 20 20 20 45 51 55 44 20 30 20 20 20 20 3b 20 | EQUD 0 ; | 00002fc0 70 68 61 73 65 20 70 69 74 63 68 20 63 68 61 6e |phase pitch chan| 00002fd0 6e 65 6c 20 30 0d 0e 4c 39 2e 73 6f 75 6e 64 5f |nel 0..L9.sound_| 00002fe0 70 69 74 63 68 31 20 20 20 20 20 20 20 45 51 55 |pitch1 EQU| 00002ff0 44 20 30 20 20 20 20 3b 20 70 68 61 73 65 20 70 |D 0 ; phase p| 00003000 69 74 63 68 20 63 68 61 6e 6e 65 6c 20 31 0d 0e |itch channel 1..| 00003010 56 39 2e 73 6f 75 6e 64 5f 70 69 74 63 68 32 20 |V9.sound_pitch2 | 00003020 20 20 20 20 20 20 45 51 55 44 20 30 20 20 20 20 | EQUD 0 | 00003030 3b 20 70 68 61 73 65 20 70 69 74 63 68 20 63 68 |; phase pitch ch| 00003040 61 6e 6e 65 6c 20 32 0d 0e 60 39 2e 73 6f 75 6e |annel 2..`9.soun| 00003050 64 5f 70 69 74 63 68 33 20 20 20 20 20 20 20 45 |d_pitch3 E| 00003060 51 55 44 20 30 20 20 20 20 3b 20 70 68 61 73 65 |QUD 0 ; phase| 00003070 20 70 69 74 63 68 20 63 68 61 6e 6e 65 6c 20 33 | pitch channel 3| 00003080 0d 0e 6a 42 2e 73 6f 75 6e 64 5f 74 69 6d 65 30 |..jB.sound_time0| 00003090 20 20 20 20 20 20 20 20 45 51 55 44 20 30 20 20 | EQUD 0 | 000030a0 20 20 3b 20 6c 61 73 74 20 74 69 6d 65 20 28 52 | ; last time (R| 000030b0 39 29 20 63 68 61 6e 6e 65 6c 20 75 70 64 61 74 |9) channel updat| 000030c0 65 64 0d 0e 74 41 2e 73 6f 75 6e 64 5f 74 69 6d |ed..tA.sound_tim| 000030d0 65 31 20 20 20 20 20 20 20 20 45 51 55 44 20 30 |e1 EQUD 0| 000030e0 20 20 20 20 3b 20 63 68 61 6e 6e 65 6c 20 31 20 | ; channel 1 | 000030f0 28 64 65 63 72 65 6d 65 6e 74 73 20 61 73 20 74 |(decrements as t| 00003100 69 6d 65 0d 0e 7e 37 2e 73 6f 75 6e 64 5f 74 69 |ime..~7.sound_ti| 00003110 6d 65 32 20 20 20 20 20 20 20 20 45 51 55 44 20 |me2 EQUD | 00003120 30 20 20 20 20 3b 20 63 68 61 6e 6e 65 6c 20 32 |0 ; channel 2| 00003130 20 20 67 6f 65 73 20 6f 6e 29 0d 0e 88 2d 2e 73 | goes on)...-.s| 00003140 6f 75 6e 64 5f 74 69 6d 65 33 20 20 20 20 20 20 |ound_time3 | 00003150 20 20 45 51 55 44 20 30 20 20 20 20 3b 20 63 68 | EQUD 0 ; ch| 00003160 61 6e 6e 65 6c 20 33 0d 0e 92 04 0d 0e 9c 37 3b |annel 3.......7;| 00003170 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |;;;;;;;;;;;;;;;;| * 000031a0 3b 3b 0d 0e a6 37 3b 20 46 69 6c 6c 20 73 6f 75 |;;...7; Fill sou| 000031b0 6e 64 20 20 62 75 66 66 65 72 20 20 20 20 20 20 |nd buffer | 000031c0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000031d0 20 20 20 20 20 20 20 20 3b 0d 0e b0 37 3b 3b 3b | ;...7;;;| 000031e0 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |;;;;;;;;;;;;;;;;| * 00003210 0d 0e ba 04 0d 0e c4 2b 3b 45 20 52 30 3d 6e 75 |.......+;E R0=nu| 00003220 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20 74 6f |mber of bytes to| 00003230 20 66 69 6c 6c 20 69 6e 20 62 75 66 66 65 72 0d | fill in buffer.| 00003240 0e ce 1c 3b 20 20 52 35 3d 62 62 63 20 63 68 61 |...; R5=bbc cha| 00003250 6e 6e 65 6c 20 6e 75 6d 62 65 72 0d 0e d8 23 3b |nnel number...#;| 00003260 20 20 52 31 34 20 6e 6f 74 20 75 73 61 62 6c 65 | R14 not usable| 00003270 20 28 69 6e 20 49 52 51 20 6d 6f 64 65 29 0d 0e | (in IRQ mode)..| 00003280 e2 1e 3b 20 20 52 65 74 75 72 6e 20 61 64 64 72 |..; Return addr| 00003290 65 73 73 20 6f 6e 20 73 74 61 63 6b 0d 0e ec 04 |ess on stack....| 000032a0 0d 0e f6 11 2e 73 6f 75 6e 64 5f 66 69 6c 6c 74 |.....sound_fillt| 000032b0 6f 0d 0f 00 1e 53 54 4d 46 44 20 52 31 33 21 2c |o....STMFD R13!,| 000032c0 7b 52 31 2d 52 34 2c 52 31 31 2d 52 31 32 7d 0d |{R1-R4,R11-R12}.| 000032d0 0f 0a 39 41 44 44 53 20 52 33 2c 52 30 2c 23 30 |..9ADDS R3,R0,#0| 000032e0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000032f0 20 3b 20 6e 75 6d 62 65 72 20 6f 66 20 62 79 74 | ; number of byt| 00003300 65 73 20 74 6f 20 64 6f 0d 0f 14 2a 4c 44 4d 4c |es to do...*LDML| 00003310 45 46 44 20 52 31 33 21 2c 7b 52 31 2d 52 34 2c |EFD R13!,{R1-R4,| 00003320 52 31 31 2d 52 31 32 2c 50 43 7d 20 3b 20 6e 6f |R11-R12,PC} ; no| 00003330 6e 65 0d 0f 1e 18 41 44 52 20 52 34 2c 73 6f 75 |ne....ADR R4,sou| 00003340 6e 64 5f 66 69 6c 6c 65 64 30 0d 0f 28 3c 4c 44 |nd_filled0..(<LD| 00003350 52 20 52 31 2c 5b 52 34 2c 52 35 2c 4c 53 4c 23 |R R1,[R4,R5,LSL#| 00003360 32 5d 20 20 20 20 20 20 20 20 20 20 3b 20 63 75 |2] ; cu| 00003370 72 72 65 6e 74 20 6f 66 66 73 65 74 20 66 69 6c |rrent offset fil| 00003380 6c 65 64 20 74 6f 0d 0f 32 1c 4c 44 52 20 52 31 |led to..2.LDR R1| 00003390 31 2c 73 6f 75 6e 64 5f 62 75 66 66 73 5f 61 64 |1,sound_buffs_ad| 000033a0 64 72 0d 0f 3c 42 41 44 44 20 52 31 31 2c 52 31 |dr..<BADD R11,R1| 000033b0 31 2c 52 35 2c 4c 53 4c 23 73 6f 75 6e 64 5f 62 |1,R5,LSL#sound_b| 000033c0 75 66 5f 73 69 7a 65 5f 6c 6f 67 25 20 3b 20 61 |uf_size_log% ; a| 000033d0 64 64 72 65 73 73 20 6f 66 20 74 68 65 20 62 75 |ddress of the bu| 000033e0 66 66 65 72 0d 0f 46 35 41 44 44 20 52 31 32 2c |ffer..F5ADD R12,| 000033f0 52 31 31 2c 23 73 6f 75 6e 64 5f 62 75 66 5f 73 |R11,#sound_buf_s| 00003400 69 7a 65 25 20 20 3b 20 65 6e 64 20 6f 66 20 74 |ize% ; end of t| 00003410 68 65 20 62 75 66 66 65 72 0d 0f 50 45 41 44 44 |he buffer..PEADD| 00003420 20 52 31 31 2c 52 31 31 2c 52 31 20 20 20 20 20 | R11,R11,R1 | 00003430 20 20 20 20 20 20 20 20 20 20 20 3b 20 61 64 64 | ; add| 00003440 72 65 73 73 20 61 74 20 77 68 69 63 68 20 74 6f |ress at which to| 00003450 20 73 74 61 72 74 20 66 69 6c 6c 69 6e 67 0d 0f | start filling..| 00003460 5a 17 41 44 52 20 52 34 2c 73 6f 75 6e 64 5f 70 |Z.ADR R4,sound_p| 00003470 69 74 63 68 30 0d 0f 64 37 4c 44 52 20 52 31 2c |itch0..d7LDR R1,| 00003480 5b 52 34 2c 52 35 2c 4c 53 4c 23 32 5d 20 20 20 |[R4,R5,LSL#2] | 00003490 20 20 20 20 20 20 20 3b 20 67 65 74 20 70 68 61 | ; get pha| 000034a0 73 65 20 70 69 74 63 68 20 69 6e 63 0d 0f 6e 15 |se pitch inc..n.| 000034b0 41 44 52 20 52 34 2c 73 6f 75 6e 64 5f 61 6d 70 |ADR R4,sound_amp| 000034c0 30 0d 0f 78 40 4c 44 52 42 20 52 34 2c 5b 52 34 |0..x@LDRB R4,[R4| 000034d0 2c 52 35 5d 20 20 20 20 20 20 20 20 20 20 20 20 |,R5] | 000034e0 20 20 20 3b 20 67 65 74 20 42 42 43 20 61 6d 70 | ; get BBC amp| 000034f0 20 66 6f 72 20 74 68 69 73 20 63 68 61 6e 6e 65 | for this channe| 00003500 6c 0d 0f 82 38 4c 44 52 20 52 30 2c 28 73 6f 75 |l...8LDR R0,(sou| 00003510 6e 64 5f 62 75 66 66 73 5f 61 64 64 72 2b 34 29 |nd_buffs_addr+4)| 00003520 20 20 20 3b 20 76 6f 6c 75 6d 65 20 73 63 61 6c | ; volume scal| 00003530 69 6e 67 20 74 61 62 6c 65 0d 0f 8c 3f 4c 44 52 |ing table...?LDR| 00003540 42 20 52 34 2c 5b 52 30 2c 52 34 5d 20 20 20 20 |B R4,[R0,R4] | 00003550 20 20 20 20 20 20 20 20 20 20 20 3b 20 73 63 61 | ; sca| 00003560 6c 65 20 76 6f 6c 75 6d 65 20 74 6f 20 56 49 44 |le volume to VID| 00003570 43 20 66 6f 72 6d 61 74 0d 0f 96 2f 52 53 42 20 |C format.../RSB | 00003580 52 34 2c 52 34 2c 23 28 31 32 37 3c 3c 31 29 20 |R4,R4,#(127<<1) | 00003590 20 20 20 20 20 20 20 20 20 20 3b 20 61 74 74 65 | ; atte| 000035a0 6e 75 61 74 69 6f 6e 0d 0f a0 32 54 45 51 20 52 |nuation...2TEQ R| 000035b0 35 2c 23 33 20 20 20 20 20 20 20 20 20 20 20 20 |5,#3 | 000035c0 20 20 20 20 20 20 20 20 20 3b 20 6e 6f 69 73 65 | ; noise| 000035d0 20 63 68 61 6e 6e 65 6c 3f 0d 0f aa 1a 42 45 51 | channel?....BEQ| 000035e0 20 73 6f 75 6e 64 5f 66 69 6c 6c 74 6f 5f 6e 6f | sound_fillto_no| 000035f0 69 73 65 0d 0f b4 16 41 44 52 20 52 30 2c 73 6f |ise....ADR R0,so| 00003600 75 6e 64 5f 66 72 65 71 30 0d 0f be 18 4c 44 52 |und_freq0....LDR| 00003610 20 52 30 2c 5b 52 30 2c 52 35 2c 4c 53 4c 23 32 | R0,[R0,R5,LSL#2| 00003620 5d 0d 0f c8 0d 54 45 51 20 52 30 2c 23 31 0d 0f |]....TEQ R0,#1..| 00003630 d2 1b 42 45 51 20 73 6f 75 6e 64 5f 66 69 6c 6c |..BEQ sound_fill| 00003640 74 6f 5f 73 70 65 61 63 68 0d 0f dc 33 4c 44 52 |to_speach...3LDR| 00003650 20 52 32 2c 28 73 6f 75 6e 64 5f 62 75 66 66 73 | R2,(sound_buffs| 00003660 5f 61 64 64 72 2b 38 29 20 20 20 3b 20 73 74 61 |_addr+8) ; sta| 00003670 6e 64 61 72 64 20 73 61 6d 70 6c 65 0d 0f e6 16 |ndard sample....| 00003680 2e 73 6f 75 6e 64 5f 66 69 6c 6c 74 6f 5f 6c 6f |.sound_fillto_lo| 00003690 6f 70 0d 0f f0 34 41 44 44 20 52 31 2c 52 31 2c |op...4ADD R1,R1,| 000036a0 52 31 2c 4c 53 4c 23 31 36 20 20 20 20 20 20 20 |R1,LSL#16 | 000036b0 20 20 20 20 3b 20 61 64 76 61 6e 63 65 20 77 61 | ; advance wa| 000036c0 76 65 66 6f 72 6d 0d 0f fa 1a 4c 44 52 42 20 52 |veform....LDRB R| 000036d0 30 2c 5b 52 32 2c 52 31 2c 4c 53 52 23 32 34 5d |0,[R2,R1,LSR#24]| 000036e0 0d 10 04 11 53 55 42 53 20 52 30 2c 52 30 2c 52 |....SUBS R0,R0,R| 000036f0 34 0d 10 0e 0f 4d 4f 56 4d 49 20 52 30 2c 23 30 |4....MOVMI R0,#0| 00003700 0d 10 18 33 53 54 52 42 20 52 30 2c 5b 52 31 31 |...3STRB R0,[R11| 00003710 5d 2c 23 31 20 20 20 20 20 20 20 20 20 20 20 20 |],#1 | 00003720 20 20 3b 20 77 72 69 74 65 20 6e 65 78 74 20 62 | ; write next b| 00003730 79 74 65 0d 10 22 0f 43 4d 50 20 52 31 31 2c 52 |yte..".CMP R11,R| 00003740 31 32 0d 10 2c 35 53 55 42 47 45 20 52 31 31 2c |12..,5SUBGE R11,| 00003750 52 31 32 2c 23 73 6f 75 6e 64 5f 62 75 66 5f 73 |R12,#sound_buf_s| 00003760 69 7a 65 25 20 3b 20 77 72 61 70 20 74 68 65 20 |ize% ; wrap the | 00003770 70 6f 69 6e 74 65 72 0d 10 36 11 53 55 42 53 20 |pointer..6.SUBS | 00003780 52 33 2c 52 33 2c 23 31 0d 10 40 19 42 48 49 20 |R3,R3,#1..@.BHI | 00003790 73 6f 75 6e 64 5f 66 69 6c 6c 74 6f 5f 6c 6f 6f |sound_fillto_loo| 000037a0 70 0d 10 4a 17 41 44 52 20 52 34 2c 73 6f 75 6e |p..J.ADR R4,soun| 000037b0 64 5f 70 69 74 63 68 30 0d 10 54 36 53 54 52 20 |d_pitch0..T6STR | 000037c0 52 31 2c 5b 52 34 2c 52 35 2c 4c 53 4c 23 32 5d |R1,[R4,R5,LSL#2]| 000037d0 20 20 20 20 20 20 20 20 20 20 3b 20 73 61 76 65 | ; save| 000037e0 20 6e 65 77 20 70 69 74 63 68 20 69 6e 63 0d 10 | new pitch inc..| 000037f0 5e 15 2e 73 6f 75 6e 64 5f 66 69 6c 6c 74 6f 5f |^..sound_fillto_| 00003800 65 6e 64 0d 10 68 20 53 55 42 20 52 31 32 2c 52 |end..h SUB R12,R| 00003810 31 32 2c 23 73 6f 75 6e 64 5f 62 75 66 5f 73 69 |12,#sound_buf_si| 00003820 7a 65 25 0d 10 72 3e 53 55 42 20 52 31 31 2c 52 |ze%..r>SUB R11,R| 00003830 31 31 2c 52 31 32 20 20 20 20 20 20 20 20 20 20 |11,R12 | 00003840 20 20 20 20 20 3b 20 6f 66 66 73 65 74 20 69 6e | ; offset in| 00003850 20 62 75 66 66 65 72 20 66 69 6c 6c 65 64 20 74 | buffer filled t| 00003860 6f 0d 10 7c 19 41 44 52 20 52 31 32 2c 73 6f 75 |o..|.ADR R12,sou| 00003870 6e 64 5f 66 69 6c 6c 65 64 30 0d 10 86 1a 53 54 |nd_filled0....ST| 00003880 52 20 52 31 31 2c 5b 52 31 32 2c 52 35 2c 4c 53 |R R11,[R12,R5,LS| 00003890 4c 23 32 5d 0d 10 90 21 4c 44 4d 46 44 20 52 31 |L#2]...!LDMFD R1| 000038a0 33 21 2c 7b 52 31 2d 52 34 2c 52 31 31 2d 52 31 |3!,{R1-R4,R11-R1| 000038b0 32 2c 50 43 7d 0d 10 9a 17 2e 73 6f 75 6e 64 5f |2,PC}.....sound_| 000038c0 66 69 6c 6c 74 6f 5f 6e 6f 69 73 65 0d 10 a4 16 |fillto_noise....| 000038d0 4c 44 52 20 52 32 2c 73 6f 75 6e 64 5f 66 72 65 |LDR R2,sound_fre| 000038e0 71 33 0d 10 ae 2e 54 53 54 20 52 32 2c 23 31 3c |q3....TST R2,#1<| 000038f0 3c 32 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |<2 | 00003900 20 20 20 20 3b 20 6c 6f 6f 6b 20 61 74 20 46 42 | ; look at FB| 00003910 0d 10 b8 21 4c 44 52 45 51 20 52 32 2c 28 73 6f |...!LDREQ R2,(so| 00003920 75 6e 64 5f 62 75 66 66 73 5f 61 64 64 72 2b 38 |und_buffs_addr+8| 00003930 29 0d 10 c2 30 41 44 44 45 51 20 52 32 2c 52 32 |)...0ADDEQ R2,R2| 00003940 2c 23 26 31 30 30 20 20 20 20 20 20 20 20 20 20 |,#&100 | 00003950 20 20 20 3b 20 70 75 6c 73 65 20 73 61 6d 70 6c | ; pulse sampl| 00003960 65 0d 10 cc 32 42 45 51 20 73 6f 75 6e 64 5f 66 |e...2BEQ sound_f| 00003970 69 6c 6c 74 6f 5f 6c 6f 6f 70 20 20 20 20 20 20 |illto_loop | 00003980 20 20 20 3b 20 70 65 72 69 6f 64 69 63 20 6e 6f | ; periodic no| 00003990 69 73 65 0d 10 d6 3b 53 54 4d 46 44 20 52 31 33 |ise...;STMFD R13| 000039a0 21 2c 7b 52 36 2d 52 37 7d 20 20 20 20 20 20 20 |!,{R6-R7} | 000039b0 20 20 20 20 20 3b 20 6e 65 65 64 20 74 77 6f 20 | ; need two | 000039c0 6d 6f 72 65 20 72 65 67 69 73 74 65 72 73 0d 10 |more registers..| 000039d0 e0 34 4c 44 52 20 52 32 2c 73 6f 75 6e 64 5f 6e |.4LDR R2,sound_n| 000039e0 6f 69 73 65 73 65 65 64 20 20 20 20 20 20 20 20 |oiseseed | 000039f0 3b 20 77 68 69 74 65 20 6e 6f 69 73 65 20 73 65 |; white noise se| 00003a00 65 64 0d 10 ea 35 52 53 42 20 52 34 2c 52 34 2c |ed...5RSB R4,R4,| 00003a10 23 28 31 32 37 3c 3c 31 29 20 20 20 20 20 20 20 |#(127<<1) | 00003a20 20 20 20 20 3b 20 72 65 63 6f 76 65 72 20 61 6d | ; recover am| 00003a30 70 6c 69 74 75 64 65 0d 10 f4 2c 82 20 52 30 2c |plitude...,. R0,| 00003a40 52 34 2c 23 31 20 20 20 20 20 20 20 20 20 20 20 |R4,#1 | 00003a50 20 20 20 20 20 20 20 3b 20 6f 74 68 65 72 20 73 | ; other s| 00003a60 69 67 6e 0d 10 fe 27 4c 44 52 20 52 36 2c 73 6f |ign...'LDR R6,so| 00003a70 75 6e 64 5f 6e 6f 69 73 65 65 6f 72 20 20 20 20 |und_noiseeor | 00003a80 20 20 20 20 20 3b 20 65 6f 72 0d 11 08 34 2e 73 | ; eor...4.s| 00003a90 66 6e 5f 6c 6f 6f 70 20 20 20 20 20 20 20 20 20 |fn_loop | 00003aa0 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 77 68 | ; wh| 00003ab0 69 74 65 20 6e 6f 69 73 65 20 6c 6f 6f 70 0d 11 |ite noise loop..| 00003ac0 12 0d 4d 4f 56 20 52 37 2c 52 31 0d 11 1c 17 41 |..MOV R7,R1....A| 00003ad0 44 44 20 52 31 2c 52 31 2c 52 31 2c 4c 53 4c 23 |DD R1,R1,R1,LSL#| 00003ae0 31 36 0d 11 26 0e 82 20 52 37 2c 52 37 2c 52 31 |16..&.. R7,R7,R1| 00003af0 0d 11 30 15 54 53 54 20 52 37 2c 23 26 34 30 30 |..0.TST R7,#&400| 00003b00 30 30 30 30 30 0d 11 3a 43 42 45 51 20 73 66 6e |00000..:CBEQ sfn| 00003b10 5f 73 6b 69 70 20 20 20 20 20 20 20 20 20 20 20 |_skip | 00003b20 20 20 20 20 20 20 20 3b 20 62 69 74 20 68 61 73 | ; bit has| 00003b30 6e 27 74 20 63 68 61 6e 67 65 64 20 73 6f 20 64 |n't changed so d| 00003b40 6f 6e 27 74 20 61 64 76 0d 11 44 14 4d 4f 56 53 |on't adv..D.MOVS| 00003b50 20 52 32 2c 52 32 2c 4c 53 52 23 31 0d 11 4e 10 | R2,R2,LSR#1..N.| 00003b60 82 43 53 20 52 32 2c 52 32 2c 52 36 0d 11 58 1a |.CS R2,R2,R6..X.| 00003b70 42 49 43 43 43 20 52 31 2c 52 31 2c 23 26 34 30 |BICCC R1,R1,#&40| 00003b80 30 30 30 30 30 30 0d 11 62 19 84 52 43 53 20 52 |000000..b..RCS R| 00003b90 31 2c 52 31 2c 23 26 34 30 30 30 30 30 30 30 0d |1,R1,#&40000000.| 00003ba0 11 6c 0d 2e 73 66 6e 5f 73 6b 69 70 0d 11 76 15 |.l..sfn_skip..v.| 00003bb0 54 53 54 20 52 31 2c 23 26 34 30 30 30 30 30 30 |TST R1,#&4000000| 00003bc0 30 0d 11 80 16 53 54 52 45 51 42 20 52 30 2c 5b |0....STREQB R0,[| 00003bd0 52 31 31 5d 2c 23 31 0d 11 8a 16 53 54 52 4e 45 |R11],#1....STRNE| 00003be0 42 20 52 34 2c 5b 52 31 31 5d 2c 23 31 0d 11 94 |B R4,[R11],#1...| 00003bf0 0f 43 4d 50 20 52 31 31 2c 52 31 32 0d 11 9e 35 |.CMP R11,R12...5| 00003c00 53 55 42 47 45 20 52 31 31 2c 52 31 32 2c 23 73 |SUBGE R11,R12,#s| 00003c10 6f 75 6e 64 5f 62 75 66 5f 73 69 7a 65 25 20 3b |ound_buf_size% ;| 00003c20 20 77 72 61 70 20 74 68 65 20 70 6f 69 6e 74 65 | wrap the pointe| 00003c30 72 0d 11 a8 11 53 55 42 53 20 52 33 2c 52 33 2c |r....SUBS R3,R3,| 00003c40 23 31 0d 11 b2 10 42 48 49 20 73 66 6e 5f 6c 6f |#1....BHI sfn_lo| 00003c50 6f 70 0d 11 bc 16 4c 44 4d 46 44 20 52 31 33 21 |op....LDMFD R13!| 00003c60 2c 7b 52 36 2d 52 37 7d 0d 11 c6 1a 53 54 52 20 |,{R6-R7}....STR | 00003c70 52 32 2c 73 6f 75 6e 64 5f 6e 6f 69 73 65 73 65 |R2,sound_noisese| 00003c80 65 64 0d 11 d0 17 53 54 52 20 52 31 2c 73 6f 75 |ed....STR R1,sou| 00003c90 6e 64 5f 70 69 74 63 68 33 0d 11 da 16 42 20 73 |nd_pitch3....B s| 00003ca0 6f 75 6e 64 5f 66 69 6c 6c 74 6f 5f 65 6e 64 0d |ound_fillto_end.| 00003cb0 11 e4 3b 2e 73 6f 75 6e 64 5f 66 69 6c 6c 74 6f |..;.sound_fillto| 00003cc0 5f 73 70 65 61 63 68 20 20 20 20 20 20 20 20 20 |_speach | 00003cd0 20 3b 20 64 69 72 65 63 74 20 61 6d 70 20 6d 6f | ; direct amp mo| 00003ce0 64 69 66 69 63 61 74 69 6f 6e 0d 11 ee 15 41 44 |dification....AD| 00003cf0 52 20 52 34 2c 73 6f 75 6e 64 5f 61 6d 70 30 0d |R R4,sound_amp0.| 00003d00 11 f8 40 4c 44 52 42 20 52 34 2c 5b 52 34 2c 52 |..@LDRB R4,[R4,R| 00003d10 35 5d 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |5] | 00003d20 20 3b 20 67 65 74 20 42 42 43 20 61 6d 70 20 66 | ; get BBC amp f| 00003d30 6f 72 20 74 68 69 73 20 63 68 61 6e 6e 65 6c 0d |or this channel.| 00003d40 12 02 28 4d 4f 56 20 52 34 2c 52 34 2c 4c 53 4c |..(MOV R4,R4,LSL| 00003d50 23 31 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |#1 | 00003d60 20 3b 20 30 2d 33 30 0d 12 0c 37 53 55 42 53 20 | ; 0-30...7SUBS | 00003d70 52 34 2c 52 34 2c 23 31 35 20 20 20 20 20 20 20 |R4,R4,#15 | 00003d80 20 20 20 20 20 20 20 20 20 3b 20 61 6d 70 6c 69 | ; ampli| 00003d90 74 75 64 65 20 2d 31 35 20 74 6f 20 31 35 0d 12 |tude -15 to 15..| 00003da0 16 0f 4d 4f 56 50 4c 20 52 30 2c 23 30 0d 12 20 |..MOVPL R0,#0.. | 00003db0 2c 4d 4f 56 4d 49 20 52 30 2c 23 31 20 20 20 20 |,MOVMI R0,#1 | 00003dc0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 00003dd0 20 73 69 67 6e 20 62 69 74 0d 12 2a 32 52 53 42 | sign bit..*2RSB| 00003de0 4d 49 20 52 34 2c 52 34 2c 23 30 20 20 20 20 20 |MI R4,R4,#0 | 00003df0 20 20 20 20 20 20 20 20 20 20 20 3b 20 6e 6f 77 | ; now| 00003e00 20 2b 76 65 20 28 31 2d 31 35 29 0d 12 34 31 4c | +ve (1-15)..41L| 00003e10 44 52 20 52 31 2c 28 73 6f 75 6e 64 5f 62 75 66 |DR R1,(sound_buf| 00003e20 66 73 5f 61 64 64 72 2b 34 29 20 20 20 3b 20 6c |fs_addr+4) ; l| 00003e30 6f 67 20 61 6d 70 20 74 61 62 6c 65 0d 12 3e 2c |og amp table..>,| 00003e40 4c 44 52 42 20 52 34 2c 5b 52 31 2c 52 34 5d 20 |LDRB R4,[R1,R4] | 00003e50 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 00003e60 56 49 44 43 20 61 6d 70 0d 12 48 3c 82 20 52 34 |VIDC amp..H<. R4| 00003e70 2c 52 34 2c 52 30 20 20 20 20 20 20 20 20 20 20 |,R4,R0 | 00003e80 20 20 20 20 20 20 20 20 3b 20 62 75 6e 67 20 69 | ; bung i| 00003e90 6e 20 73 69 67 6e 20 74 6f 20 67 65 74 20 73 61 |n sign to get sa| 00003ea0 6d 70 6c 65 0d 12 52 16 41 44 52 20 52 32 2c 73 |mple..R.ADR R2,s| 00003eb0 6f 75 6e 64 5f 74 69 6d 65 30 0d 12 5c 39 4c 44 |ound_time0..\9LD| 00003ec0 52 20 52 30 2c 5b 52 32 2c 52 35 2c 4c 53 4c 23 |R R0,[R2,R5,LSL#| 00003ed0 32 5d 20 20 20 20 20 20 20 20 20 20 3b 20 67 65 |2] ; ge| 00003ee0 74 20 74 69 6d 65 20 6c 61 73 74 20 75 70 64 61 |t time last upda| 00003ef0 74 65 64 0d 12 66 1a 2e 73 6f 75 6e 64 5f 66 69 |ted..f..sound_fi| 00003f00 6c 6c 74 6f 5f 73 70 65 61 63 68 5f 31 0d 12 70 |llto_speach_1..p| 00003f10 14 53 54 52 42 20 52 34 2c 5b 52 31 31 5d 2c 23 |.STRB R4,[R11],#| 00003f20 31 0d 12 7a 11 53 55 42 20 52 30 2c 52 30 2c 23 |1..z.SUB R0,R0,#| 00003f30 39 36 0d 12 84 0f 43 4d 50 20 52 31 31 2c 52 31 |96....CMP R11,R1| 00003f40 32 0d 12 8e 35 53 55 42 47 45 20 52 31 31 2c 52 |2...5SUBGE R11,R| 00003f50 31 32 2c 23 73 6f 75 6e 64 5f 62 75 66 5f 73 69 |12,#sound_buf_si| 00003f60 7a 65 25 20 3b 20 77 72 61 70 20 74 68 65 20 70 |ze% ; wrap the p| 00003f70 6f 69 6e 74 65 72 0d 12 98 11 53 55 42 53 20 52 |ointer....SUBS R| 00003f80 33 2c 52 33 2c 23 31 0d 12 a2 1d 42 48 49 20 73 |3,R3,#1....BHI s| 00003f90 6f 75 6e 64 5f 66 69 6c 6c 74 6f 5f 73 70 65 61 |ound_fillto_spea| 00003fa0 63 68 5f 31 0d 12 ac 19 3b 53 54 52 20 52 30 2c |ch_1....;STR R0,| 00003fb0 5b 52 32 2c 52 35 2c 4c 53 4c 23 32 5d 0d 12 b6 |[R2,R5,LSL#2]...| 00003fc0 16 42 20 73 6f 75 6e 64 5f 66 69 6c 6c 74 6f 5f |.B sound_fillto_| 00003fd0 65 6e 64 0d 12 c0 3b 2e 73 6f 75 6e 64 5f 6e 6f |end...;.sound_no| 00003fe0 69 73 65 73 65 65 64 20 45 51 55 44 20 26 34 34 |iseseed EQUD &44| 00003ff0 36 44 36 39 35 34 20 3b 20 77 68 69 74 65 20 6e |6D6954 ; white n| 00004000 6f 69 73 65 20 73 65 65 64 20 28 52 32 29 0d 12 |oise seed (R2)..| 00004010 ca 3a 2e 73 6f 75 6e 64 5f 6e 6f 69 73 65 65 6f |.:.sound_noiseeo| 00004020 72 20 20 45 51 55 44 20 26 38 32 44 34 45 31 42 |r EQUD &82D4E1B| 00004030 38 20 3b 20 77 68 69 74 65 20 6e 6f 69 73 65 20 |8 ; white noise | 00004040 65 6f 72 20 28 52 36 29 0d 12 d4 04 0d 12 de 37 |eor (R6).......7| 00004050 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |;;;;;;;;;;;;;;;;| * 00004080 3b 3b 3b 0d 12 e8 37 3b 20 56 6f 69 63 65 20 67 |;;;...7; Voice g| 00004090 65 6e 65 72 61 74 6f 72 20 20 20 20 20 20 20 20 |enerator | 000040a0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000040b0 20 20 20 20 20 20 20 20 20 3b 0d 12 f2 37 3b 3b | ;...7;;| 000040c0 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |;;;;;;;;;;;;;;;;| * 000040f0 3b 0d 12 fc 04 0d 13 06 15 2e 73 6f 75 6e 64 5f |;.........sound_| 00004100 62 75 66 66 73 5f 61 64 64 72 0d 13 10 35 45 51 |buffs_addr...5EQ| 00004110 55 44 20 30 20 20 20 20 20 20 20 20 20 20 20 20 |UD 0 | 00004120 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 61 64 | ; ad| 00004130 64 72 65 73 73 20 6f 66 20 62 75 66 66 65 72 0d |dress of buffer.| 00004140 13 1a 30 45 51 55 44 20 30 20 20 20 20 20 20 20 |..0EQUD 0 | 00004150 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00004160 20 3b 20 76 6f 6c 75 6d 65 20 74 61 62 6c 65 0d | ; volume table.| 00004170 13 24 32 45 51 55 44 20 30 20 20 20 20 20 20 20 |.$2EQUD 0 | 00004180 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00004190 20 3b 20 73 61 6d 70 6c 65 20 61 64 64 72 65 73 | ; sample addres| 000041a0 73 0d 13 2e 31 45 51 55 44 20 30 20 20 20 20 20 |s...1EQUD 0 | 000041b0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000041c0 20 20 20 3b 20 73 74 61 63 6b 20 61 64 64 72 65 | ; stack addre| 000041d0 73 73 0d 13 38 04 0d 13 42 0a 3b 20 53 43 43 42 |ss..8...B.; SCCB| 000041e0 0d 13 4c 1e 3b 20 23 30 20 62 30 2d 62 37 20 41 |..L.; #0 b0-b7 A| 000041f0 72 63 20 76 6f 6c 75 6d 65 20 28 52 31 29 0d 13 |rc volume (R1)..| 00004200 56 2c 3b 20 23 34 20 70 68 61 73 65 20 61 63 63 |V,; #4 phase acc| 00004210 75 6d 75 6c 61 74 6f 72 20 28 62 30 2d 62 31 35 |umulator (b0-b15| 00004220 3d 69 6e 63 29 20 28 52 32 29 0d 13 60 0a 3b 20 |=inc) (R2)..`.; | 00004230 23 38 20 2d 0d 13 6a 30 3b 20 23 31 32 20 6e 75 |#8 -..j0; #12 nu| 00004240 6d 62 65 72 20 6f 66 20 62 75 66 66 65 72 20 66 |mber of buffer f| 00004250 69 6c 6c 73 20 6c 65 66 74 20 74 6f 20 64 6f 20 |ills left to do | 00004260 28 52 34 29 0d 13 74 27 3b 20 23 31 36 20 62 62 |(R4)..t'; #16 bb| 00004270 63 20 63 68 61 6e 6e 65 6c 20 6e 75 6d 62 65 72 |c channel number| 00004280 20 28 30 2d 33 29 20 28 52 35 29 0d 13 7e 2a 3b | (0-3) (R5)..~*;| 00004290 20 23 32 30 20 56 6f 6c 75 6d 65 20 73 63 61 6c | #20 Volume scal| 000042a0 65 64 20 6c 6f 67 20 61 6d 70 20 74 61 62 6c 65 |ed log amp table| 000042b0 20 28 52 36 29 0d 13 88 04 0d 13 92 16 2e 73 6f | (R6).........so| 000042c0 75 6e 64 5f 76 6f 69 63 65 68 65 61 64 65 72 0d |und_voiceheader.| 000042d0 13 9c 11 42 20 73 6f 75 6e 64 5f 76 66 69 6c 6c |...B sound_vfill| 000042e0 0d 13 a6 11 42 20 73 6f 75 6e 64 5f 76 66 69 6c |....B sound_vfil| 000042f0 6c 0d 13 b0 11 42 20 73 6f 75 6e 64 5f 76 66 69 |l....B sound_vfi| 00004300 6c 6c 0d 13 ba 14 42 20 73 6f 75 6e 64 5f 76 67 |ll....B sound_vg| 00004310 61 74 65 6f 66 66 0d 13 c4 18 42 20 73 6f 75 6e |ateoff....B soun| 00004320 64 5f 76 69 6e 73 74 61 6e 74 69 61 74 65 0d 13 |d_vinstantiate..| 00004330 ce 13 4c 44 4d 46 44 20 52 31 33 21 2c 7b 50 43 |..LDMFD R13!,{PC| 00004340 7d 0d 13 d8 13 4c 44 4d 46 44 20 52 31 33 21 2c |}....LDMFD R13!,| 00004350 7b 50 43 7d 0d 13 e2 2a 45 51 55 44 20 73 6f 75 |{PC}...*EQUD sou| 00004360 6e 64 5f 76 6f 69 63 65 6e 61 6d 65 2d 73 6f 75 |nd_voicename-sou| 00004370 6e 64 5f 76 6f 69 63 65 68 65 61 64 65 72 0d 13 |nd_voiceheader..| 00004380 ec 14 2e 73 6f 75 6e 64 5f 76 6f 69 63 65 6e 61 |...sound_voicena| 00004390 6d 65 0d 13 f6 1a 45 51 55 53 20 22 36 35 30 32 |me....EQUS "6502| 000043a0 45 6d 75 6c 61 74 6f 72 22 2b bd 30 0d 14 00 09 |Emulator"+.0....| 000043b0 41 4c 49 47 4e 0d 14 0a 04 0d 14 14 1e 3b 45 20 |ALIGN........;E | 000043c0 52 65 74 75 72 6e 20 61 64 64 72 65 73 73 20 6f |Return address o| 000043d0 6e 20 73 74 61 63 6b 0d 14 1e 23 3b 20 20 52 31 |n stack...#; R1| 000043e0 34 20 6e 6f 74 20 75 73 61 62 6c 65 20 28 69 6e |4 not usable (in| 000043f0 20 49 52 51 20 6d 6f 64 65 29 0d 14 28 04 0d 14 | IRQ mode)..(...| 00004400 32 10 2e 73 6f 75 6e 64 5f 76 66 69 6c 6c 0d 14 |2..sound_vfill..| 00004410 3c 39 4c 44 4d 46 44 20 52 39 2c 7b 52 31 2d 52 |<9LDMFD R9,{R1-R| 00004420 36 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |6} | 00004430 3b 20 52 35 3d 62 62 63 20 63 68 61 6e 6e 65 6c |; R5=bbc channel| 00004440 20 6e 75 6d 62 65 72 0d 14 46 16 41 44 52 20 52 | number..F.ADR R| 00004450 31 2c 73 6f 75 6e 64 5f 72 65 61 64 30 0d 14 50 |1,sound_read0..P| 00004460 39 4c 44 52 20 52 32 2c 5b 52 31 2c 52 35 2c 4c |9LDR R2,[R1,R5,L| 00004470 53 4c 23 32 5d 20 20 20 20 20 20 20 20 20 20 3b |SL#2] ;| 00004480 20 6f 66 66 73 65 74 20 6f 66 20 75 6e 72 65 61 | offset of unrea| 00004490 64 20 64 61 74 61 0d 14 5a 18 41 44 52 20 52 31 |d data..Z.ADR R1| 000044a0 2c 73 6f 75 6e 64 5f 66 69 6c 6c 65 64 30 0d 14 |,sound_filled0..| 000044b0 64 3b 4c 44 52 20 52 30 2c 5b 52 31 2c 52 35 2c |d;LDR R0,[R1,R5,| 000044c0 4c 53 4c 23 32 5d 20 20 20 20 20 20 20 20 20 20 |LSL#2] | 000044d0 3b 20 6f 66 66 73 65 74 20 62 75 66 66 65 72 20 |; offset buffer | 000044e0 66 69 6c 6c 65 64 20 74 6f 0d 14 6e 11 53 55 42 |filled to..n.SUB| 000044f0 53 20 52 30 2c 52 30 2c 52 32 0d 14 78 38 41 44 |S R0,R0,R2..x8AD| 00004500 44 4d 49 20 52 30 2c 52 30 2c 23 73 6f 75 6e 64 |DMI R0,R0,#sound| 00004510 5f 62 75 66 5f 73 69 7a 65 25 20 20 3b 20 61 6d |_buf_size% ; am| 00004520 6f 75 6e 74 20 69 6e 20 74 68 65 20 62 75 66 66 |ount in the buff| 00004530 65 72 0d 14 82 37 52 53 42 53 20 52 30 2c 52 30 |er...7RSBS R0,R0| 00004540 2c 23 32 30 38 20 20 20 20 20 20 20 20 20 20 20 |,#208 | 00004550 20 20 20 20 3b 20 61 6d 6f 75 6e 74 20 65 78 74 | ; amount ext| 00004560 72 61 20 6e 65 65 64 65 64 0d 14 8c 16 42 4c 45 |ra needed....BLE| 00004570 20 73 6f 75 6e 64 5f 66 69 6c 6c 5f 72 65 74 0d | sound_fill_ret.| 00004580 14 96 19 41 44 52 20 52 31 2c 73 6f 75 6e 64 5f |...ADR R1,sound_| 00004590 66 69 6c 6c 5f 72 65 74 0d 14 a0 3f 53 54 4d 46 |fill_ret...?STMF| 000045a0 44 20 52 31 33 21 2c 7b 52 31 7d 20 20 20 20 20 |D R13!,{R1} | 000045b0 20 20 20 20 20 20 20 20 20 20 3b 20 70 75 74 20 | ; put | 000045c0 72 65 74 75 72 6e 20 61 64 64 72 65 73 73 20 6f |return address o| 000045d0 6e 20 73 74 61 63 6b 0d 14 aa 41 42 20 73 6f 75 |n stack...AB sou| 000045e0 6e 64 5f 66 69 6c 6c 74 6f 20 20 20 20 20 20 20 |nd_fillto | 000045f0 20 20 20 20 20 20 20 20 20 3b 20 65 6e 73 75 72 | ; ensur| 00004600 65 20 74 68 65 20 62 75 66 66 65 72 20 66 75 6c |e the buffer ful| 00004610 6c 20 65 6e 6f 75 67 68 0d 14 b4 13 2e 73 6f 75 |l enough.....sou| 00004620 6e 64 5f 66 69 6c 6c 5f 72 65 74 0d 14 be 16 41 |nd_fill_ret....A| 00004630 44 52 20 52 31 2c 73 6f 75 6e 64 5f 72 65 61 64 |DR R1,sound_read| 00004640 30 0d 14 c8 36 4c 44 52 20 52 30 2c 5b 52 31 2c |0...6LDR R0,[R1,| 00004650 52 35 2c 4c 53 4c 23 32 5d 20 20 20 20 20 20 20 |R5,LSL#2] | 00004660 20 20 20 3b 20 6f 66 66 20 6f 66 20 75 6e 72 65 | ; off of unre| 00004670 61 64 20 64 61 74 61 0d 14 d2 43 41 44 44 20 52 |ad data...CADD R| 00004680 32 2c 52 30 2c 23 32 30 38 20 20 20 20 20 20 20 |2,R0,#208 | 00004690 20 20 20 20 20 20 20 20 20 3b 20 6e 65 77 20 6f | ; new o| 000046a0 66 66 73 65 74 20 61 66 74 65 72 20 77 65 27 76 |ffset after we'v| 000046b0 65 20 66 69 6e 69 73 68 65 64 0d 14 dc 1b 43 4d |e finished....CM| 000046c0 50 20 52 32 2c 23 73 6f 75 6e 64 5f 62 75 66 5f |P R2,#sound_buf_| 000046d0 73 69 7a 65 25 0d 14 e6 2b 53 55 42 47 45 20 52 |size%...+SUBGE R| 000046e0 32 2c 52 32 2c 23 73 6f 75 6e 64 5f 62 75 66 5f |2,R2,#sound_buf_| 000046f0 73 69 7a 65 25 20 20 3b 20 77 72 61 70 20 69 74 |size% ; wrap it| 00004700 0d 14 f0 18 53 54 52 20 52 32 2c 5b 52 31 2c 52 |....STR R2,[R1,R| 00004710 35 2c 4c 53 4c 23 32 5d 0d 14 fa 1b 4c 44 52 20 |5,LSL#2]....LDR | 00004720 52 32 2c 73 6f 75 6e 64 5f 62 75 66 66 73 5f 61 |R2,sound_buffs_a| 00004730 64 64 72 0d 15 04 3c 41 44 44 20 52 32 2c 52 32 |ddr...<ADD R2,R2| 00004740 2c 52 35 2c 4c 53 4c 23 73 6f 75 6e 64 5f 62 75 |,R5,LSL#sound_bu| 00004750 66 5f 73 69 7a 65 5f 6c 6f 67 25 20 3b 20 61 64 |f_size_log% ; ad| 00004760 64 72 65 73 73 20 6f 66 20 62 75 66 66 65 72 0d |dress of buffer.| 00004770 15 0e 31 41 44 44 20 52 33 2c 52 32 2c 23 73 6f |..1ADD R3,R2,#so| 00004780 75 6e 64 5f 62 75 66 5f 73 69 7a 65 25 20 20 20 |und_buf_size% | 00004790 20 3b 20 65 6e 64 20 6f 66 20 62 75 66 66 65 72 | ; end of buffer| 000047a0 0d 15 18 33 41 44 44 20 52 32 2c 52 32 2c 52 30 |...3ADD R2,R2,R0| 000047b0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000047c0 20 20 3b 20 63 75 72 72 65 6e 74 20 61 64 64 72 | ; current addr| 000047d0 65 73 73 0d 15 22 39 2e 73 6f 75 6e 64 5f 66 69 |ess.."9.sound_fi| 000047e0 6c 6c 5f 6c 6f 6f 70 20 20 20 20 20 20 20 20 20 |ll_loop | 000047f0 20 20 20 20 20 3b 20 4e 42 20 41 6d 70 20 61 6c | ; NB Amp al| 00004800 72 65 61 64 79 20 73 63 61 6c 65 64 0d 15 2c 31 |ready scaled..,1| 00004810 4c 44 52 42 20 52 30 2c 5b 52 32 5d 2c 23 31 20 |LDRB R0,[R2],#1 | 00004820 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 | ; | 00004830 67 65 74 20 6e 65 78 74 20 62 79 74 65 0d 15 36 |get next byte..6| 00004840 15 53 54 52 42 20 52 30 2c 5b 52 31 32 5d 2c 52 |.STRB R0,[R12],R| 00004850 31 31 0d 15 40 0d 43 4d 50 20 52 32 2c 52 33 0d |11..@.CMP R2,R3.| 00004860 15 4a 20 53 55 42 47 45 20 52 32 2c 52 33 2c 23 |.J SUBGE R2,R3,#| 00004870 73 6f 75 6e 64 5f 62 75 66 5f 73 69 7a 65 25 0d |sound_buf_size%.| 00004880 15 54 31 4c 44 52 42 20 52 30 2c 5b 52 32 5d 2c |.T1LDRB R0,[R2],| 00004890 23 31 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |#1 | 000048a0 20 3b 20 67 65 74 20 6e 65 78 74 20 62 79 74 65 | ; get next byte| 000048b0 0d 15 5e 15 53 54 52 42 20 52 30 2c 5b 52 31 32 |..^.STRB R0,[R12| 000048c0 5d 2c 52 31 31 0d 15 68 0d 43 4d 50 20 52 32 2c |],R11..h.CMP R2,| 000048d0 52 33 0d 15 72 20 53 55 42 47 45 20 52 32 2c 52 |R3..r SUBGE R2,R| 000048e0 33 2c 23 73 6f 75 6e 64 5f 62 75 66 5f 73 69 7a |3,#sound_buf_siz| 000048f0 65 25 0d 15 7c 31 4c 44 52 42 20 52 30 2c 5b 52 |e%..|1LDRB R0,[R| 00004900 32 5d 2c 23 31 20 20 20 20 20 20 20 20 20 20 20 |2],#1 | 00004910 20 20 20 20 3b 20 67 65 74 20 6e 65 78 74 20 62 | ; get next b| 00004920 79 74 65 0d 15 86 15 53 54 52 42 20 52 30 2c 5b |yte....STRB R0,[| 00004930 52 31 32 5d 2c 52 31 31 0d 15 90 0d 43 4d 50 20 |R12],R11....CMP | 00004940 52 32 2c 52 33 0d 15 9a 20 53 55 42 47 45 20 52 |R2,R3... SUBGE R| 00004950 32 2c 52 33 2c 23 73 6f 75 6e 64 5f 62 75 66 5f |2,R3,#sound_buf_| 00004960 73 69 7a 65 25 0d 15 a4 31 4c 44 52 42 20 52 30 |size%...1LDRB R0| 00004970 2c 5b 52 32 5d 2c 23 31 20 20 20 20 20 20 20 20 |,[R2],#1 | 00004980 20 20 20 20 20 20 20 3b 20 67 65 74 20 6e 65 78 | ; get nex| 00004990 74 20 62 79 74 65 0d 15 ae 15 53 54 52 42 20 52 |t byte....STRB R| 000049a0 30 2c 5b 52 31 32 5d 2c 52 31 31 0d 15 b8 0d 43 |0,[R12],R11....C| 000049b0 4d 50 20 52 32 2c 52 33 0d 15 c2 20 53 55 42 47 |MP R2,R3... SUBG| 000049c0 45 20 52 32 2c 52 33 2c 23 73 6f 75 6e 64 5f 62 |E R2,R3,#sound_b| 000049d0 75 66 5f 73 69 7a 65 25 0d 15 cc 0f 43 4d 50 20 |uf_size%....CMP | 000049e0 52 31 32 2c 52 31 30 0d 15 d6 17 42 4c 54 20 73 |R12,R10....BLT s| 000049f0 6f 75 6e 64 5f 66 69 6c 6c 5f 6c 6f 6f 70 0d 15 |ound_fill_loop..| 00004a00 e0 36 4d 4f 56 20 52 30 2c 23 38 20 20 20 20 20 |.6MOV R0,#8 | 00004a10 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00004a20 3b 20 76 6f 69 63 65 20 73 74 69 6c 6c 20 61 63 |; voice still ac| 00004a30 74 69 76 65 0d 15 ea 13 4c 44 4d 46 44 20 52 31 |tive....LDMFD R1| 00004a40 33 21 2c 7b 50 43 7d 0d 15 f4 04 0d 15 fe 37 3b |3!,{PC}.......7;| 00004a50 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |;;;;;;;;;;;;;;;;| * 00004a80 3b 3b 0d 16 08 37 3b 20 70 72 69 6e 74 20 6f 75 |;;...7; print ou| 00004a90 74 20 64 65 62 75 67 20 64 61 74 61 20 2d 20 63 |t debug data - c| 00004aa0 75 72 72 65 6e 74 20 63 68 61 6e 6e 65 6c 20 73 |urrent channel s| 00004ab0 65 74 74 69 6e 67 73 20 3b 0d 16 12 37 3b 3b 3b |ettings ;...7;;;| 00004ac0 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |;;;;;;;;;;;;;;;;| * 00004af0 0d 16 1c 04 0d 16 26 1f 3b 58 20 52 31 3d 63 68 |......&.;X R1=ch| 00004b00 61 6e 6e 65 6c 20 62 65 69 6e 67 20 63 68 61 6e |annel being chan| 00004b10 67 65 64 0d 16 30 04 0d 16 3a 10 2e 73 6f 75 6e |ged..0...:..soun| 00004b20 64 5f 64 65 62 75 67 0d 16 44 1a 53 54 4d 46 44 |d_debug..D.STMFD| 00004b30 20 52 31 33 21 2c 7b 52 30 2d 52 31 2c 52 31 34 | R13!,{R0-R1,R14| 00004b40 7d 0d 16 4e 0c 53 57 49 20 26 31 31 46 0d 16 58 |}..N.SWI &11F..X| 00004b50 0c 53 57 49 20 26 31 30 30 0d 16 62 0d 4d 4f 56 |.SWI &100..b.MOV| 00004b60 20 52 30 2c 52 31 0d 16 6c 31 53 57 49 20 22 58 | R0,R1..l1SWI "X| 00004b70 4f 53 5f 57 72 69 74 65 43 22 20 20 20 20 20 20 |OS_WriteC" | 00004b80 20 20 20 20 20 20 20 20 3b 20 6a 75 6d 70 20 74 | ; jump t| 00004b90 6f 20 72 6f 77 20 6e 0d 16 76 0d 4d 4f 56 20 52 |o row n..v.MOV R| 00004ba0 30 2c 52 31 0d 16 80 2b 42 4c 20 73 6f 75 6e 64 |0,R1...+BL sound| 00004bb0 5f 64 65 62 75 67 32 20 20 20 20 20 20 20 20 20 |_debug2 | 00004bc0 20 20 20 20 20 20 3b 20 63 68 61 6e 6e 65 6c 0d | ; channel.| 00004bd0 16 8a 17 41 44 52 20 52 31 34 2c 73 6f 75 6e 64 |...ADR R14,sound| 00004be0 5f 66 72 65 71 30 0d 16 94 19 4c 44 52 20 52 30 |_freq0....LDR R0| 00004bf0 2c 5b 52 31 34 2c 52 31 2c 4c 53 4c 23 32 5d 0d |,[R14,R1,LSL#2].| 00004c00 16 9e 28 42 4c 20 73 6f 75 6e 64 5f 64 65 62 75 |..(BL sound_debu| 00004c10 67 32 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |g2 | 00004c20 20 3b 20 66 72 65 71 0d 16 a8 16 41 44 52 20 52 | ; freq....ADR R| 00004c30 31 34 2c 73 6f 75 6e 64 5f 61 6d 70 30 0d 16 b2 |14,sound_amp0...| 00004c40 14 4c 44 52 42 20 52 30 2c 5b 52 31 34 2c 52 31 |.LDRB R0,[R14,R1| 00004c50 5d 0d 16 bc 27 42 4c 20 73 6f 75 6e 64 5f 64 65 |]...'BL sound_de| 00004c60 62 75 67 32 20 20 20 20 20 20 20 20 20 20 20 20 |bug2 | 00004c70 20 20 20 3b 20 61 6d 70 0d 16 c6 19 4c 44 4d 46 | ; amp....LDMF| 00004c80 44 20 52 31 33 21 2c 7b 52 30 2d 52 31 2c 50 43 |D R13!,{R0-R1,PC| 00004c90 7d 0d 16 d0 04 0d 16 da 05 5d 0d 16 e4 07 3d 22 |}........]....="| 00004ca0 22 0d 16 ee 04 0d 16 f8 10 f4 20 4d 49 53 43 20 |"......... MISC | 00004cb0 53 54 55 46 46 0d 17 02 04 0d 17 0c 11 dd 20 a4 |STUFF......... .| 00004cc0 73 6f 75 6e 64 5f 6d 69 73 63 0d 17 16 0a 5b 4f |sound_misc....[O| 00004cd0 50 54 20 70 0d 17 20 04 0d 17 2a 19 3b 45 20 52 |PT p.. ...*.;E R| 00004ce0 30 3d 6e 75 6d 62 65 72 20 74 6f 20 70 72 69 6e |0=number to prin| 00004cf0 74 0d 17 34 15 3b 58 20 4e 75 6d 62 65 72 20 70 |t..4.;X Number p| 00004d00 72 69 6e 74 65 64 0d 17 3e 04 0d 17 48 36 2e 73 |rinted..>...H6.s| 00004d10 6f 75 6e 64 5f 64 65 62 75 67 32 20 20 20 20 20 |ound_debug2 | 00004d20 20 20 3b 20 6f 75 74 70 75 74 20 6e 75 6d 62 65 | ; output numbe| 00004d30 72 20 69 6e 20 52 30 20 74 6f 20 64 65 62 75 67 |r in R0 to debug| 00004d40 0d 17 52 1a 53 54 4d 46 44 20 52 31 33 21 2c 7b |..R.STMFD R13!,{| 00004d50 52 30 2d 52 32 2c 52 31 34 7d 0d 17 5c 1a 41 44 |R0-R2,R14}..\.AD| 00004d60 52 20 52 31 2c 73 6f 75 6e 64 5f 64 65 62 75 67 |R R1,sound_debug| 00004d70 5f 62 75 66 0d 17 66 0e 4d 4f 56 20 52 32 2c 23 |_buf..f.MOV R2,#| 00004d80 31 36 0d 17 70 19 53 57 49 20 22 58 4f 53 5f 43 |16..p.SWI "XOS_C| 00004d90 6f 6e 76 65 72 74 48 65 78 38 22 0d 17 7a 14 53 |onvertHex8"..z.S| 00004da0 57 49 20 22 58 4f 53 5f 57 72 69 74 65 30 22 0d |WI "XOS_Write0".| 00004db0 17 84 0c 53 57 49 20 26 31 32 30 0d 17 8e 19 4c |...SWI &120....L| 00004dc0 44 4d 46 44 20 52 31 33 21 2c 7b 52 30 2d 52 32 |DMFD R13!,{R0-R2| 00004dd0 2c 50 43 7d 0d 17 98 14 2e 73 6f 75 6e 64 5f 64 |,PC}.....sound_d| 00004de0 65 62 75 67 5f 62 75 66 0d 17 a2 12 a4 73 6f 75 |ebug_buf.....sou| 00004df0 6e 64 5f 6d 65 6d 28 31 36 29 0d 17 ac 04 0d 17 |nd_mem(16)......| 00004e00 b6 20 3b 45 20 52 30 3d 63 68 61 6e 6e 65 6c 20 |. ;E R0=channel | 00004e10 6e 75 6d 62 65 72 2d 31 20 28 30 2d 37 29 0d 17 |number-1 (0-7)..| 00004e20 c0 25 3b 20 20 52 65 74 75 72 6e 20 61 64 64 72 |.%; Return addr| 00004e30 65 73 73 20 6f 6e 20 74 6f 70 20 6f 66 20 73 74 |ess on top of st| 00004e40 61 63 6b 0d 17 ca 04 0d 17 d4 17 2e 73 6f 75 6e |ack.........soun| 00004e50 64 5f 76 69 6e 73 74 61 6e 74 69 61 74 65 0d 17 |d_vinstantiate..| 00004e60 de 16 53 54 4d 46 44 20 52 31 33 21 2c 7b 52 30 |..STMFD R13!,{R0| 00004e70 2d 52 35 7d 0d 17 e8 37 4d 4f 56 20 52 35 2c 52 |-R5}...7MOV R5,R| 00004e80 30 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |0 | 00004e90 20 20 20 20 20 20 3b 20 73 61 76 65 20 63 68 61 | ; save cha| 00004ea0 6e 6e 65 6c 20 6e 75 6d 62 65 72 0d 17 f2 0d 4d |nnel number....M| 00004eb0 4f 56 20 52 30 2c 23 30 0d 17 fc 0d 4d 4f 56 20 |OV R0,#0....MOV | 00004ec0 52 31 2c 23 30 0d 18 06 0d 4d 4f 56 20 52 32 2c |R1,#0....MOV R2,| 00004ed0 23 30 0d 18 10 0d 4d 4f 56 20 52 33 2c 23 30 0d |#0....MOV R3,#0.| 00004ee0 18 1a 0d 4d 4f 56 20 52 34 2c 23 30 0d 18 24 1a |...MOV R4,#0..$.| 00004ef0 53 57 49 20 22 58 53 6f 75 6e 64 5f 43 6f 6e 66 |SWI "XSound_Conf| 00004f00 69 67 75 72 65 22 0d 18 2e 32 41 44 44 20 52 30 |igure"...2ADD R0| 00004f10 2c 52 35 2c 23 31 20 20 20 20 20 20 20 20 20 20 |,R5,#1 | 00004f20 20 20 20 20 20 20 20 20 3b 20 63 68 61 6e 6e 65 | ; channe| 00004f30 6c 20 6e 75 6d 62 65 72 0d 18 38 0e 4d 4f 56 20 |l number..8.MOV | 00004f40 52 31 2c 23 32 30 0d 18 42 13 4c 44 52 20 52 32 |R1,#20..B.LDR R2| 00004f50 2c 5b 52 33 2c 23 31 32 5d 0d 18 4c 43 53 57 49 |,[R3,#12]..LCSWI| 00004f60 20 22 58 53 6f 75 6e 64 5f 57 72 69 74 65 43 6f | "XSound_WriteCo| 00004f70 6e 74 72 6f 6c 42 6c 6f 63 6b 22 20 20 20 20 20 |ntrolBlock" | 00004f80 20 20 20 20 20 3b 20 76 6f 6c 75 6d 65 20 73 63 | ; volume sc| 00004f90 61 6c 65 64 20 6c 6f 67 20 61 6d 70 0d 18 56 10 |aled log amp..V.| 00004fa0 41 44 44 20 52 30 2c 52 35 2c 23 31 0d 18 60 0e |ADD R0,R5,#1..`.| 00004fb0 4d 4f 56 20 52 31 2c 23 31 36 0d 18 6a 36 4d 4f |MOV R1,#16..j6MO| 00004fc0 56 20 52 32 2c 52 35 20 20 20 20 20 20 20 20 20 |V R2,R5 | 00004fd0 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 62 62 | ; bb| 00004fe0 63 20 63 68 61 6e 6e 65 6c 20 6e 75 6d 62 65 72 |c channel number| 00004ff0 0d 18 74 0d 43 4d 50 20 52 32 2c 23 34 0d 18 7e |..t.CMP R2,#4..~| 00005000 28 4d 4f 56 43 53 20 52 32 2c 23 30 20 20 20 20 |(MOVCS R2,#0 | 00005010 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 3b | ;| 00005020 20 63 6c 69 70 0d 18 88 22 53 57 49 20 22 58 53 | clip..."SWI "XS| 00005030 6f 75 6e 64 5f 57 72 69 74 65 43 6f 6e 74 72 6f |ound_WriteContro| 00005040 6c 42 6c 6f 63 6b 22 0d 18 92 19 4c 44 4d 46 44 |lBlock"....LDMFD| 00005050 20 52 31 33 21 2c 7b 52 30 2d 52 35 2c 50 43 7d | R13!,{R0-R5,PC}| 00005060 0d 18 9c 04 0d 18 a6 13 2e 73 6f 75 6e 64 5f 76 |.........sound_v| 00005070 67 61 74 65 6f 66 66 0d 18 b0 0d 4d 4f 56 20 52 |gateoff....MOV R| 00005080 30 2c 23 30 0d 18 ba 17 2e 73 6f 75 6e 64 5f 67 |0,#0.....sound_g| 00005090 61 74 65 6f 66 66 5f 6c 6f 6f 70 0d 18 c4 15 53 |ateoff_loop....S| 000050a0 54 52 42 20 52 30 2c 5b 52 31 32 5d 2c 52 31 31 |TRB R0,[R12],R11| 000050b0 0d 18 ce 16 53 54 52 42 20 52 30 2c 5b 52 31 32 |....STRB R0,[R12| 000050c0 5d 2c 52 31 31 20 0d 18 d8 15 53 54 52 42 20 52 |],R11 ....STRB R| 000050d0 30 2c 5b 52 31 32 5d 2c 52 31 31 0d 18 e2 15 53 |0,[R12],R11....S| 000050e0 54 52 42 20 52 30 2c 5b 52 31 32 5d 2c 52 31 31 |TRB R0,[R12],R11| 000050f0 0d 18 ec 0f 43 4d 50 20 52 31 32 2c 52 31 30 0d |....CMP R12,R10.| 00005100 18 f6 1a 42 4c 54 20 73 6f 75 6e 64 5f 67 61 74 |...BLT sound_gat| 00005110 65 6f 66 66 5f 6c 6f 6f 70 0d 19 00 0d 4d 4f 56 |eoff_loop....MOV| 00005120 20 52 30 2c 23 31 0d 19 0a 13 4c 44 4d 46 44 20 | R0,#1....LDMFD | 00005130 52 31 33 21 2c 7b 50 43 7d 0d 19 14 04 0d 19 1e |R13!,{PC}.......| 00005140 37 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |7;;;;;;;;;;;;;;;| 00005150 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |;;;;;;;;;;;;;;;;| * 00005170 3b 3b 3b 3b 0d 19 28 37 3b 20 44 69 76 69 64 65 |;;;;..(7; Divide| 00005180 20 72 6f 75 74 69 6e 65 20 20 20 20 20 20 20 20 | routine | 00005190 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 000051a0 20 20 20 20 20 20 20 20 20 20 3b 0d 19 32 37 3b | ;..27;| 000051b0 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b |;;;;;;;;;;;;;;;;| * 000051e0 3b 3b 0d 19 3c 04 0d 19 46 24 5c 45 20 52 30 3d |;;..<...F$\E R0=| 000051f0 6e 75 6d 65 72 61 74 6f 72 20 20 20 52 31 3d 64 |numerator R1=d| 00005200 65 6e 6f 6d 69 6e 61 74 6f 72 0d 19 50 37 5c 58 |enominator..P7\X| 00005210 20 52 30 3d 52 30 20 44 69 76 20 52 31 20 20 20 | R0=R0 Div R1 | 00005220 52 32 3d 52 30 20 4d 6f 64 20 52 31 20 20 20 20 |R2=R0 Mod R1 | 00005230 52 30 2d 52 33 20 63 6f 72 72 75 70 74 65 64 20 |R0-R3 corrupted | 00005240 7c 0d 19 5a 04 0d 19 64 0c 2e 64 69 76 5f 6d 6f ||..Z...d..div_mo| 00005250 64 0d 19 6e 33 4d 4f 56 20 52 32 2c 23 30 20 20 |d..n3MOV R2,#0 | 00005260 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00005270 20 20 20 5c 20 63 6c 65 61 72 20 72 65 6d 61 69 | \ clear remai| 00005280 6e 64 65 72 0d 19 78 34 41 44 44 53 20 52 30 2c |nder..x4ADDS R0,| 00005290 52 30 2c 52 30 20 20 20 20 20 20 20 20 20 20 20 |R0,R0 | 000052a0 20 20 20 20 20 20 5c 20 64 6f 75 62 6c 65 20 6e | \ double n| 000052b0 75 6d 65 72 61 74 6f 72 0d 19 82 30 52 53 42 20 |umerator...0RSB | 000052c0 52 31 2c 52 31 2c 23 30 20 20 20 20 20 20 20 20 |R1,R1,#0 | 000052d0 20 20 20 20 20 20 20 20 20 20 5c 20 6e 65 67 61 | \ nega| 000052e0 74 65 20 64 65 6e 6f 6d 0d 19 8c 0e 4d 4f 56 20 |te denom....MOV | 000052f0 52 33 2c 23 33 32 0d 19 96 0e 2e 64 69 76 5f 6d |R3,#32.....div_m| 00005300 6f 64 5f 31 0d 19 a0 34 41 44 43 53 20 52 32 2c |od_1...4ADCS R2,| 00005310 52 31 2c 52 32 2c 4c 53 4c 23 31 3a 53 55 42 43 |R1,R2,LSL#1:SUBC| 00005320 43 20 52 32 2c 52 32 2c 52 31 3a 41 44 43 53 20 |C R2,R2,R1:ADCS | 00005330 52 30 2c 52 30 2c 52 30 0d 19 aa 34 41 44 43 53 |R0,R0,R0...4ADCS| 00005340 20 52 32 2c 52 31 2c 52 32 2c 4c 53 4c 23 31 3a | R2,R1,R2,LSL#1:| 00005350 53 55 42 43 43 20 52 32 2c 52 32 2c 52 31 3a 41 |SUBCC R2,R2,R1:A| 00005360 44 43 53 20 52 30 2c 52 30 2c 52 30 0d 19 b4 34 |DCS R0,R0,R0...4| 00005370 41 44 43 53 20 52 32 2c 52 31 2c 52 32 2c 4c 53 |ADCS R2,R1,R2,LS| 00005380 4c 23 31 3a 53 55 42 43 43 20 52 32 2c 52 32 2c |L#1:SUBCC R2,R2,| 00005390 52 31 3a 41 44 43 53 20 52 30 2c 52 30 2c 52 30 |R1:ADCS R0,R0,R0| 000053a0 0d 19 be 34 41 44 43 53 20 52 32 2c 52 31 2c 52 |...4ADCS R2,R1,R| 000053b0 32 2c 4c 53 4c 23 31 3a 53 55 42 43 43 20 52 32 |2,LSL#1:SUBCC R2| 000053c0 2c 52 32 2c 52 31 3a 41 44 43 53 20 52 30 2c 52 |,R2,R1:ADCS R0,R| 000053d0 30 2c 52 30 0d 19 c8 10 53 55 42 20 52 33 2c 52 |0,R0....SUB R3,R| 000053e0 33 2c 23 34 0d 19 d2 0d 54 45 51 20 52 33 2c 23 |3,#4....TEQ R3,#| 000053f0 30 0d 19 dc 36 42 4e 45 20 64 69 76 5f 6d 6f 64 |0...6BNE div_mod| 00005400 5f 31 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |_1 | 00005410 20 20 20 5c 20 44 4f 20 ac 20 43 4f 52 52 55 50 | \ DO . CORRUP| 00005420 54 20 43 41 52 52 59 0d 19 e6 0f 4d 4f 56 53 20 |T CARRY....MOVS | 00005430 50 43 2c 52 31 34 0d 19 f0 04 0d 19 fa 0e 2e 6c |PC,R14.........l| 00005440 6f 67 5f 73 74 61 72 74 0d 1a 04 1a 53 54 4d 46 |og_start....STMF| 00005450 44 20 52 31 33 21 2c 7b 52 30 2d 52 32 2c 52 31 |D R13!,{R0-R2,R1| 00005460 34 7d 0d 1a 0e 0f 4d 4f 56 20 52 30 2c 23 26 38 |4}....MOV R0,#&8| 00005470 38 0d 1a 18 14 41 44 52 20 52 31 2c 6c 6f 67 5f |8....ADR R1,log_| 00005480 66 6e 61 6d 65 0d 1a 22 11 53 57 49 20 22 4f 53 |fname..".SWI "OS| 00005490 5f 46 69 6e 64 22 0d 1a 2c 15 53 54 52 20 52 30 |_Find"..,.STR R0| 000054a0 2c 6c 6f 67 5f 68 61 6e 64 6c 65 0d 1a 36 19 4c |,log_handle..6.L| 000054b0 44 4d 46 44 20 52 31 33 21 2c 7b 52 30 2d 52 32 |DMFD R13!,{R0-R2| 000054c0 2c 50 43 7d 0d 1a 40 26 2e 6c 6f 67 5f 66 6e 61 |,PC}..@&.log_fna| 000054d0 6d 65 20 45 51 55 53 20 22 24 2e 54 4d 50 2e 4c |me EQUS "$.TMP.L| 000054e0 6f 67 46 69 6c 65 22 2b bd 30 0d 1a 4a 09 41 4c |ogFile"+.0..J.AL| 000054f0 49 47 4e 0d 1a 54 16 2e 6c 6f 67 5f 68 61 6e 64 |IGN..T..log_hand| 00005500 6c 65 20 45 51 55 44 20 30 0d 1a 5e 14 2e 6c 6f |le EQUD 0..^..lo| 00005510 67 5f 74 65 6d 70 20 45 51 55 44 20 30 0d 1a 68 |g_temp EQUD 0..h| 00005520 04 0d 1a 72 0c 2e 6c 6f 67 5f 65 6e 64 0d 1a 7c |...r..log_end..|| 00005530 1a 53 54 4d 46 44 20 52 31 33 21 2c 7b 52 30 2d |.STMFD R13!,{R0-| 00005540 52 32 2c 52 31 34 7d 0d 1a 86 0d 4d 4f 56 20 52 |R2,R14}....MOV R| 00005550 30 2c 23 30 0d 1a 90 15 4c 44 52 20 52 31 2c 6c |0,#0....LDR R1,l| 00005560 6f 67 5f 68 61 6e 64 6c 65 0d 1a 9a 11 53 57 49 |og_handle....SWI| 00005570 20 22 4f 53 5f 46 69 6e 64 22 0d 1a a4 19 4c 44 | "OS_Find"....LD| 00005580 4d 46 44 20 52 31 33 21 2c 7b 52 30 2d 52 32 2c |MFD R13!,{R0-R2,| 00005590 50 43 7d 0d 1a ae 04 0d 1a b8 14 3b 20 52 30 3d |PC}........; R0=| 000055a0 77 6f 72 64 20 74 6f 20 6c 6f 67 0d 1a c2 04 0d |word to log.....| 000055b0 1a cc 0d 2e 6c 6f 67 5f 77 6f 72 64 0d 1a d6 1a |....log_word....| 000055c0 53 54 4d 46 44 20 52 31 33 21 2c 7b 52 30 2d 52 |STMFD R13!,{R0-R| 000055d0 35 2c 52 31 34 7d 0d 1a e0 13 53 54 52 20 52 30 |5,R14}....STR R0| 000055e0 2c 6c 6f 67 5f 74 65 6d 70 0d 1a ea 0d 4d 4f 56 |,log_temp....MOV| 000055f0 20 52 30 2c 23 32 0d 1a f4 15 4c 44 52 20 52 31 | R0,#2....LDR R1| 00005600 2c 6c 6f 67 5f 68 61 6e 64 6c 65 0d 1a fe 13 41 |,log_handle....A| 00005610 44 52 20 52 32 2c 6c 6f 67 5f 74 65 6d 70 0d 1b |DR R2,log_temp..| 00005620 08 0d 4d 4f 56 20 52 33 2c 23 34 0d 1b 12 11 53 |..MOV R3,#4....S| 00005630 57 49 20 22 4f 53 5f 47 42 50 42 22 0d 1b 1c 19 |WI "OS_GBPB"....| 00005640 4c 44 4d 46 44 20 52 31 33 21 2c 7b 52 30 2d 52 |LDMFD R13!,{R0-R| 00005650 35 2c 50 43 7d 0d 1b 26 04 0d 1b 30 05 5d 0d 1b |5,PC}..&...0.]..| 00005660 3a 07 3d 22 22 0d 1b 44 04 0d 1b 4e 14 dd 20 a4 |:.=""..D...N.. .| 00005670 73 6f 75 6e 64 5f 6d 65 6d 28 61 25 29 0d 1b 58 |sound_mem(a%)..X| 00005680 11 50 25 2b 3d 61 25 3a 4f 25 2b 3d 61 25 0d 1b |.P%+=a%:O%+=a%..| 00005690 62 07 3d 22 22 0d ff |b.=""..| 00005697