mirror of
https://github.com/mgcaret/rom4x.git
synced 2025-01-02 12:30:18 +00:00
Beep fix similar to Q.D.s
This commit is contained in:
parent
81f5a54aed
commit
6f8912c500
39
rom5x/B1_FB3C_rom5x_dispatch.s
Normal file
39
rom5x/B1_FB3C_rom5x_dispatch.s
Normal 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
|
5
rom5x/B1_FBE2_bell1_hijack_b1.s
Normal file
5
rom5x/B1_FBE2_bell1_hijack_b1.s
Normal file
@ -0,0 +1,5 @@
|
||||
#include "iic+.defs"
|
||||
.text
|
||||
* = $fbe2 ; ~29 bytes free here
|
||||
jmp $fb3c
|
||||
|
@ -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
|
@ -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})"
|
||||
nzc = 0
|
||||
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)
|
||||
addr += 1
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user