2024-10-27 21:50:48 +01:00
|
|
|
%import textio
|
|
|
|
%zeropage basicsafe
|
2024-10-18 22:22:34 +02:00
|
|
|
|
2024-11-04 04:28:27 +01:00
|
|
|
main {
|
2024-10-29 22:57:54 +01:00
|
|
|
sub start() {
|
2024-11-04 23:26:21 +01:00
|
|
|
basic_area.routine1()
|
|
|
|
hiram_area.routine2()
|
|
|
|
|
|
|
|
; copy the kernal area routine to actual kernal address space $f800
|
|
|
|
sys.memcopy(&kernal_area.routine3, $f800, 255)
|
|
|
|
|
|
|
|
; how to call the routine using manual bank switching:
|
|
|
|
; c64.banks(%101) ; bank out kernal rom
|
|
|
|
; call($f800) ; call our routine
|
|
|
|
; c64.banks(%111) ; kernal back
|
|
|
|
|
|
|
|
; how to use prog8's automatic bank switching:
|
|
|
|
romsub @bank %101 $f800 = kernal_routine()
|
|
|
|
|
|
|
|
kernal_routine()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
kernal_area {
|
|
|
|
; this routine is actually copied to kernal address space first
|
|
|
|
; we cannot use CHROUT when the kernal is banked out so we write to the screen directly
|
|
|
|
asmsub routine3() {
|
|
|
|
%asm {{
|
|
|
|
lda #<_message
|
|
|
|
ldy #>_message
|
|
|
|
sta $fe
|
|
|
|
sty $ff
|
|
|
|
ldy #0
|
|
|
|
- lda ($fe),y
|
|
|
|
beq +
|
|
|
|
sta $0400+240,y
|
|
|
|
iny
|
|
|
|
bne -
|
|
|
|
+ rts
|
|
|
|
|
|
|
|
_message
|
|
|
|
.enc 'screen'
|
|
|
|
.text "hello from kernal area $f800",0
|
|
|
|
.enc 'none'
|
|
|
|
; !notreached!
|
|
|
|
}}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
basic_area $a000 {
|
|
|
|
sub routine1() {
|
|
|
|
txt.print("hello from basic rom area ")
|
|
|
|
txt.print_uwhex(&routine1, true)
|
2024-11-04 04:28:27 +01:00
|
|
|
txt.nl()
|
2024-11-04 23:26:21 +01:00
|
|
|
}
|
|
|
|
}
|
2024-11-04 04:28:27 +01:00
|
|
|
|
2024-11-04 23:26:21 +01:00
|
|
|
hiram_area $ca00 {
|
|
|
|
sub routine2() {
|
|
|
|
txt.print("hello from hiram area ")
|
|
|
|
txt.print_uwhex(&routine2, true)
|
|
|
|
txt.nl()
|
2024-11-03 13:26:28 +01:00
|
|
|
}
|
|
|
|
}
|
2024-11-04 23:26:21 +01:00
|
|
|
|