1
0
mirror of https://github.com/dschmenk/PLASMA.git synced 2025-01-21 17:31:31 +00:00

Prepare HLin assemblyizing

This commit is contained in:
David Schmenk 2024-09-02 12:05:35 -07:00
parent d979f0ffed
commit 748eaa342d

View File

@ -470,66 +470,52 @@ asm _dcgrXorPlotH
end
def dcgrHLin(x1, x2, y)#0
byte pix7, mask
byte pix7, div7l, div7r
word pix7addr
pix7addr = hgrscanl[y] + (hgrscanh[y] << 8) + ((divmod7[x1] & $F8) >> 2)
if x1 == x2
dcgrPlot(x1, y)
else
div7l = (divmod7[x1] & $F8) >> 2
div7r = (divmod7[x2] & $F8) >> 2
pix7 = divmod7[x1] & 7
while x1 <= x2
mask = auxclrmsk[pix7]
if mask
^page1x
if mask & $80
^(pix7addr+1) = (^(pix7addr+1) & ~mask) | (mask & auxclrh)
else
^pix7addr = (^pix7addr & ~mask) | (mask & auxclrl)
fin
fin
mask = memclrmsk[pix7]
if mask
^page1m
if mask & $80
^(pix7addr+1) = (^(pix7addr+1) & ~mask) | (mask & memclrh)
else
^pix7addr = (^pix7addr & ~mask) | (mask & memclrl)
fin
fin
if div7l < div7r
while pix7 < 7
dcgrPlot(x1, y)
x1++
pix7++
if pix7 == 7
pix7 = 0;
pix7addr = pix7addr + 2
loop
div7l++
pix7addr = hgrscanl[y] + (hgrscanh[y] << 8) + div7l
while div7l < div7r
^page1x
^pix7addr = auxclrl
^page1m
^pix7addr = memclrl
pix7addr++
^page1x
^pix7addr = auxclrh
^page1m
^pix7addr = memclrh
pix7addr++
x1 = x1 + 7
div7l++
loop
fin
if div7l == div7r
while x1 <= x2
dcgrPlot(x1, y)
x1++
loop
fin
fin
end
def dcgrVLin(y1, y2, x)#0
byte pix7, div7, mask
word pix7addr
byte y
pix7 = divmod7[x] & 7
div7 = (divmod7[x] & $F8) >> 2
while y1 <= y2
pix7addr = hgrscanl[y1] + (hgrscanh[y1] << 8) + div7
mask = auxclrmsk[pix7]
if mask
^page1x
if mask & $80
^(pix7addr+1) = (^(pix7addr+1) & ~mask) | (mask & auxclrh)
else
^pix7addr = (^pix7addr & ~mask) | (mask & auxclrl)
fin
fin
mask = memclrmsk[pix7]
if mask
^page1m
if mask & $80
^(pix7addr+1) = (^(pix7addr+1) & ~mask) | (mask & memclrh)
else
^pix7addr = (^pix7addr & ~mask) | (mask & memclrl)
fin
fin
y1++
loop
for y = y1 to y2
dcgrPlot(x, y)
next
end
def dcgrScan(x, y, w, scanptr)#0
byte pix7, c, mask
@ -670,11 +656,11 @@ def dcgrTest#0
setlinespans(@dcgrHLin, @dcgrVLin)
for i = 0 to 191 step 4
dhgrColor(i)
line(0, 0, 139, i)
linespans(0, 0, 139, i)
next
for i = 139 downto 0 step 4
dhgrColor(i)
line(0, 0, i, 191)
linespans(0, 0, i, 191)
next
pixblk = heapalloc(16/2*20)
dhgrDst(0, 0, 2, 20, pixblk)