4cade/src/fx/fx.dhgr.soft.diagonal.a

297 lines
6.0 KiB
Plaintext
Raw Normal View History

2020-11-20 23:17:06 +00:00
;license:MIT
;(c) 2019-2020 by 4am
;
!cpu 6502
!to "build/FX/DHGR.SOFT.DIAG",plain
*=$6000
pass = $fb
y = $fc
row = $fd
col = $fe
counter = $ff
hgrlo = $0200 ; [$C0 bytes, main memory only]
hgr1hi = $0300 ; [$C0 bytes, main memory only]
!macro RESET_HGR_CALC_BY_7 {
lda $27
sec
sbc #$1c
sta $27
eor #$60
sta $3d
}
2020-11-21 04:33:59 +00:00
!macro COPY_BIT_BY .src1, .dest1, .copymask {
lda (.src1),y
eor (.dest1),y ; merge source and destination bits
and .copymask ; isolate the bits to replace, zero the rest
eor (.dest1),y ; unmerge source and destination bits, leaves 'to keep' destination bits intact
sta (.dest1),y ; write the result
}
2020-11-20 23:17:06 +00:00
!source "src/fx/macros.a"
!source "src/fx/fx.dhgr.common.a"
+COPY_SELF_TO_AUXMEM
sta $C005
ldx #48
- lda copymasks1_aux-1, x
sta copymasks1-1, x
dex
bne -
sta $C004
+BUILD_HGR_LOOKUP_TABLES_X_IS_ALREADY_0 hgrlo, hgr1hi
lda #(40+24+7-1) ; columns + rows + blocks per row - 1
sta counter
lda #39
sta col
ColLoop
lda #23
sta row
ldy col
sty y
RowLoop
lda row
asl
asl
asl
tax
lda hgrlo, x
sta $26
sta $3c
lda hgr1hi, x
sta $27
eor #$60
sta $3d
lda #2
sta pass
PassLoop
ldy y
+IS_Y_OFFSCREEN
+LBCS @block2
clc
!for i, 0, 7 {
2020-11-21 04:33:59 +00:00
+COPY_BIT_BY $3c, $26, copymasks1+i
2020-11-20 23:17:06 +00:00
!if i < 7 {
+HGR_INC_WITHIN_BLOCK
}
}
+RESET_HGR_CALC_BY_7
@block2
iny
+IS_Y_OFFSCREEN
+LBCS @block3
clc
!for i, 0, 7 {
2020-11-21 04:33:59 +00:00
+COPY_BIT_BY $3c, $26, copymasks2+i
2020-11-20 23:17:06 +00:00
!if i < 7 {
+HGR_INC_WITHIN_BLOCK
}
}
+RESET_HGR_CALC_BY_7
@block3
iny
+IS_Y_OFFSCREEN
+LBCS @block4
clc
!for i, 0, 7 {
2020-11-21 04:33:59 +00:00
+COPY_BIT_BY $3c, $26, copymasks3+i
2020-11-20 23:17:06 +00:00
!if i < 7 {
+HGR_INC_WITHIN_BLOCK
}
}
+RESET_HGR_CALC_BY_7
@block4
iny
+IS_Y_OFFSCREEN
+LBCS @block5
clc
!for i, 0, 7 {
2020-11-21 04:33:59 +00:00
+COPY_BIT_BY $3c, $26, copymasks4+i
2020-11-20 23:17:06 +00:00
!if i < 7 {
+HGR_INC_WITHIN_BLOCK
}
}
+RESET_HGR_CALC_BY_7
@block5
iny
+IS_Y_OFFSCREEN
+LBCS @block6
clc
!for i, 0, 7 {
2020-11-21 04:33:59 +00:00
+COPY_BIT_BY $3c, $26, copymasks5+i
2020-11-20 23:17:06 +00:00
!if i < 7 {
+HGR_INC_WITHIN_BLOCK
}
}
+RESET_HGR_CALC_BY_7
@block6
iny
+IS_Y_OFFSCREEN
+LBCS @block7
clc
!for i, 0, 7 {
2020-11-21 04:33:59 +00:00
+COPY_BIT_BY $3c, $26, copymasks6+i
2020-11-20 23:17:06 +00:00
!if i < 7 {
+HGR_INC_WITHIN_BLOCK
}
}
+RESET_HGR_CALC_BY_7
@block7
iny
+IS_Y_OFFSCREEN
+LBCS @nextrow
clc
!for i, 0, 7 {
lda ($3c),y
sta ($26),y
!if i < 7 {
+HGR_INC_WITHIN_BLOCK
}
}
+RESET_HGR_CALC_BY_7
@nextrow
sta $C003
sta $C005
dec pass
+LBNE PassLoop
sta $C002
sta $C004
ldy y
iny
sty y
dec row
+LBPL RowLoop
lda $c000
bmi @exit
dec col
dec counter
+LBNE ColLoop
@exit rts
;1GFEDCBA ->
;1GGFFEED (main) +
;1DCCBBAA (aux)
copymasks1
!byte %00000000
!byte %00000000
!byte %00000000
!byte %10000001
!byte %10000001
!byte %00000000
!byte %00000000
!byte %00000000
copymasks2
!byte %00000000
!byte %00000000
!byte %10000110
!byte %10000001
!byte %10000001
!byte %10010110
!byte %00000000
!byte %00000000
copymasks3
!byte %00000000
!byte %00000000
!byte %10000111
!byte %10000111
!byte %10000111
!byte %10000111
!byte %10000000
!byte %10000000
copymasks4
!byte %00000000
!byte %10011001
!byte %10000001
!byte %10011111
!byte %10000111
!byte %10000111
!byte %10011001
!byte %00000000
copymasks5
!byte %00000000
!byte %10011111
!byte %10011111
!byte %10011111
!byte %10011111
!byte %10011111
!byte %10011111
!byte %00000000
copymasks6
!byte %11100110
!byte %10011111
!byte %11111111
!byte %10011111
!byte %11111111
!byte %10011111
!byte %10011111
!byte %11100110
copymasks1_aux
!byte %00000000
!byte %00000000
!byte %00000000
!byte %11000000
!byte %11000000
!byte %00000000
!byte %00000000
!byte %00000000
copymasks2_aux
!byte %00000000
!byte %00000000
!byte %10110000
!byte %11000000
!byte %11000000
!byte %10110000
!byte %00000000
!byte %00000000
copymasks3_aux
!byte %00000000
!byte %00000000
!byte %11110000
!byte %11110000
!byte %11110000
!byte %11110000
!byte %00000000
!byte %00000000
copymasks4_aux
!byte %00000000
!byte %11001100
!byte %11110000
!byte %11111100
!byte %11110000
!byte %11110000
!byte %11001100
!byte %00000000
copymasks5_aux
!byte %00000000
!byte %11111100
!byte %11111100
!byte %11111100
!byte %11111100
!byte %11111100
!byte %11111100
!byte %00000000
copymasks6_aux
!byte %10110011
!byte %11111100
!byte %11111111
!byte %11111100
!byte %11111111
!byte %11111100
!byte %11111100
!byte %10110011