1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-12 02:30:44 +00:00
cc65/libsrc/c64/soft80_kclrscr.s

77 lines
1.5 KiB
ArmAsm
Raw Normal View History

2015-10-12 14:40:12 +02:00
;
; Groepaz/Hitmen, 12.10.2015
;
; lowlevel kclrscr for soft80 implementation
;
.export soft80_kclrscr
.import soft80_kplot
.import soft80_internal_bgcolor, soft80_internal_cellcolor
2015-10-06 19:33:43 +02:00
.importzp ptr1
.include "c64.inc"
.include "soft80.inc"
soft80_kclrscr:
2015-10-06 19:33:43 +02:00
lda #<soft80_bitmap
sta ptr1
lda #>soft80_bitmap
sta ptr1+1
lda #$ff
2015-10-06 19:33:43 +02:00
ldx #$1f
@lp2:
ldy #0
@lp1:
sta (ptr1),y
iny
bne @lp1
inc ptr1+1
dex
bne @lp2
;ldx #$00
@lp3:
sta soft80_bitmap+$1e40,x
inx
2015-10-06 19:33:43 +02:00
bne @lp3
.if SOFT80COLORVOODOO = 1
lda soft80_internal_bgcolor
2015-10-12 15:54:08 +02:00
jsr clear ; clear color ram
.endif
sei
ldy $01
2015-10-12 15:54:08 +02:00
lda #$34 ; enable RAM under I/O
sta $01
lda soft80_internal_cellcolor
and #$f0
ora soft80_internal_bgcolor
2015-10-12 15:54:08 +02:00
jsr clear ; clear vram
sty $01
cli
ldx #0
ldy #0
clc
jmp soft80_kplot
2015-10-06 19:33:43 +02:00
; clear loop for colram and vram
clear:
;ldx #$00
@lp1:
sta soft80_colram,x
sta soft80_colram+$100,x
sta soft80_colram+$200,x
sta soft80_colram+$2e8,x
inx
bne @lp1
rts