optimized gfx2.vertical_line for highres 4c mode

This commit is contained in:
Irmen de Jong 2021-04-28 00:29:21 +02:00
parent 3bf335e0a0
commit a5961cbeab
2 changed files with 62 additions and 64 deletions

View File

@ -292,15 +292,15 @@ _done
}
sub vertical_line(uword x, uword y, uword height, ubyte color) {
position(x,y)
when active_mode {
1, 5 -> {
; monochrome, either resolution
; note for the 1 bpp modes we can't use vera's auto increment mode because we have to 'or' the pixel data in place.
; TODO use TWO vera adress pointers simultaneously one for reading, one for writing, so auto-increment IS possible
position(x,y)
cx16.VERA_ADDR_H &= %00000111 ; no auto advance
cx16.r15 = gfx2.plot.bits[x as ubyte & 7] ; bitmask
if active_mode>=5
if active_mode==5
cx16.r14 = 640/8
else
cx16.r14 = 320/8
@ -385,6 +385,7 @@ _done
4 -> {
; lores 256c
; set vera auto-increment to 320 pixel increment (=next line)
position(x,y)
cx16.VERA_ADDR_H = cx16.VERA_ADDR_H & %00000111 | (14<<4)
%asm {{
ldy height
@ -398,31 +399,23 @@ _done
}
6 -> {
; highres 4c
; note for this mode we can't use vera's auto increment mode because we have to 'or' the pixel data in place.
; TODO use TWO vera adress pointers simultaneously one for reading, one for writing, so auto-increment IS possible
cx16.VERA_ADDR_H &= %00000111 ; no auto advance
; TODO also mostly usable for lores 4c?
void addr_mul_24_for_highres_4c(y, x) ; 24 bits result is in r0 and r1L (highest byte)
; TODO optimize this vertical line loop in pure assembly
; use TWO vera adress pointers simultaneously one for reading, one for writing, so auto-increment is possible
if height==0
return
position2(x,y,true)
cx16.VERA_CTRL = 0
cx16.VERA_ADDR_H = cx16.VERA_ADDR_H & %00000111 | (13<<4) ; 160 increment = 1 line in 640 px 4c mode
cx16.VERA_CTRL = 1
cx16.VERA_ADDR_H = cx16.VERA_ADDR_H & %00000111 | (13<<4) ; 160 increment = 1 line in 640 px 4c mode
color &= 3
color <<= gfx2.plot.shift4c[lsb(x) & 3]
ubyte mask = gfx2.plot.mask4c[lsb(x) & 3]
repeat height {
ubyte value = cx16.vpeek(lsb(cx16.r1), cx16.r0) & mask | color
cx16.vpoke(lsb(cx16.r1), cx16.r0, value)
%asm {{
; 24 bits add 160 (640/4)
clc
lda cx16.r0
adc #640/4
sta cx16.r0
lda cx16.r0+1
adc #0
sta cx16.r0+1
bcc +
inc cx16.r1
+
lda cx16.VERA_DATA0
and mask
ora color
sta cx16.VERA_DATA1
}}
}
}
@ -680,6 +673,20 @@ _done
}
}
sub position2(uword @zp x, uword y, ubyte also_port_1) {
position(x, y)
if also_port_1 {
when active_mode {
1, 5 -> cx16.vaddr(0, cx16.r0, 1, 1)
; TODO modes 2, 3
4, 6 -> {
ubyte bank = lsb(cx16.r1)
cx16.vaddr(bank, cx16.r0, 1, 1)
}
}
}
}
inline asmsub next_pixel(ubyte color @A) {
; -- sets the next pixel byte to the graphics chip.
; for 8 bpp screens this will plot 1 pixel.
@ -765,7 +772,7 @@ _done
1, 5 -> {
; monochrome mode, either resolution
cx16.r2 = 40
if active_mode>=5
if active_mode==5
cx16.r2 = 80
while @(sctextptr) {
chardataptr = charset_addr + (@(sctextptr) as uword)*8

View File

@ -1,50 +1,41 @@
%import textio
%zeropage basicsafe
%import conv
%import gfx2
main {
sub start() {
ubyte uu
cx16.rambank(1)
sys.memcopy(&banked.double, $a000, 100)
cx16.rambank(0)
txt.nl()
gfx2.screen_mode(6) ; high res 4 colors
gfx2.text_charset(3)
gfx2.text(10, 10, 1, @"Hello!")
uword ww
uu = 99
txt.print_ub(uu)
txt.nl()
callfar($01, $a000, &uu)
txt.print_ub(uu)
c64.SETTIM(0,0,0)
uu = '\n'
callrom($00, $ffd2, &uu)
uu = 'a'
callrom($00, $ffd2, &uu)
uu = '!'
callrom($00, $ffd2, &uu)
uu = '\n'
callrom($00, $ffd2, &uu)
repeat 1 {
uword xx
; gfx2.monochrome_stipple(true)
; for xx in 0 to 639 {
; gfx2.vertical_line(xx, 20, 220, 1)
; }
; gfx2.monochrome_stipple(false)
for xx in 0 to 639 {
gfx2.vertical_line(xx, 20, 450, 1)
}
for xx in 0 to 639 {
gfx2.vertical_line(xx, 20, 450, 2)
}
for xx in 0 to 639 {
gfx2.vertical_line(xx, 20, 450, 3)
}
for xx in 0 to 639 {
gfx2.vertical_line(xx, 20, 450, 0)
}
}
; cx16.rombank(0)
; %asm{{
; lda #13
; jsr $ffd2
; lda #'a'
; jsr $ffd2
; lda #13
; jsr $ffd2
; }}
; cx16.rombank(4)
}
}
banked {
asmsub double(ubyte number @A) -> ubyte @A {
%asm {{
asl a
rts
}}
uword time = c64.RDTIM16()
conv.str_uw(time)
gfx2.text(100, 10, 1, conv.string_out)
repeat {
}
}
}