Beep fix similar to Q.D.s

This commit is contained in:
mgcaret 2017-03-16 20:07:36 -07:00
parent 81f5a54aed
commit 6f8912c500
4 changed files with 45 additions and 18 deletions

View File

@ -0,0 +1,39 @@
#include "iic+.defs"
.text
* = $fb3c ; ~165 bytes free here
cmp #$a9 ; reset patch
bne chk2
jmp reset5x
chk2: cmp #$ea ; boot patch
bne chk3
jmp boot5x
chk3: cmp #$40 ; beep
bne dowait
; "classic air raid beep"
; inspired by http://quinndunki.com/blondihacks/?p=2471
jsr $fcb5 ; (new) WAIT for .1 sec delay
ldy #$c0
obell2: lda #$0c
jsr owait ; old wait for correct sound
lda $c030
dey
bne obell2
bra dexit ; back to caller
dowait: jsr $fcb5 ; do delay if anything else
lda #>($fbe2-1) ; return to other bank here (in BELL1)
pha ; by pushing address onto
lda #<($fbe2-1) ; the stack
pha
lda #$00 ; in case someone assumes this
dexit: jmp swrts2 ; back to other bank
; old wait - no ACIA access to enforce delay at
; accelerated speeds, speaker delay tkes care of it
; when we do the old beep
owait: sec
owait2: pha
owait3: sbc #$01
bne owait3
pla
sbc #$01
bne owait2
rts

View File

@ -0,0 +1,5 @@
#include "iic+.defs"
.text
* = $fbe2 ; ~29 bytes free here
jmp $fb3c

View File

@ -1,17 +0,0 @@
#include "iic+.defs"
.text
* = $fbe2 ; ~29 bytes free here
cmp #$a9 ; reset patch
bne chk2
jmp reset5x
chk2: cmp #$ea ; boot patch
bne dowait
jmp boot5x
dowait: jsr $fcb5 ; do delay if anything else
lda #>($fbe2-1) ; return to other bank here
pha ; by pushing address onto
lda #<($fbe2-1) ; the stack
pha
lda #$00 ; in case someone assumes this
jmp swrts2 ; back to other bank
; 28 bytes, will have to move if we get bigger

View File

@ -39,7 +39,7 @@ task :build_rom => [:assemble] do
puts "Loading #{t} into bank #{bnum} @ $#{badd.to_s(16)}, file addr $#{addr.to_s(16)}, len $#{fl.to_s(16)} (#{fl})" puts "Loading #{t} into bank #{bnum} @ $#{badd.to_s(16)}, file addr $#{addr.to_s(16)}, len $#{fl.to_s(16)} (#{fl})"
nzc = 0 nzc = 0
fc.each_byte do |b| fc.each_byte do |b|
nzc += 1 if rom.getbyte(addr) != 0 nzc += 1 if rom.getbyte(addr) != 0 && rom.getbyte(addr) != b
rom.setbyte(addr, b) rom.setbyte(addr, b)
addr += 1 addr += 1
end end