2019-09-14 03:34:32 +02:00
|
|
|
|
2019-09-16 22:55:08 +02:00
|
|
|
#if VERA_VERSION == 7
|
|
|
|
|
|
|
|
const int24 VERA_COMPOSER_CTRL = $40040
|
|
|
|
const int24 VERA_PALETTE = $40200
|
|
|
|
const int24 VERA_LAYER_1 = $40000
|
|
|
|
const int24 VERA_LAYER_2 = $40010
|
|
|
|
const int24 VERA_SPRITE_CTRL = $40020
|
|
|
|
const int24 VERA_SPRITES = $40800
|
2019-09-14 03:34:32 +02:00
|
|
|
|
|
|
|
volatile byte vera_addr_hi @ $9f20
|
|
|
|
volatile byte vera_addr_mi @ $9f21
|
|
|
|
volatile byte vera_addr_lo @ $9f22
|
2019-09-16 22:55:08 +02:00
|
|
|
|
|
|
|
#elseif VERA_VERSION == 8
|
|
|
|
|
|
|
|
const int24 VERA_COMPOSER_CTRL = $F0000
|
|
|
|
const int24 VERA_PALETTE = $F1000
|
|
|
|
const int24 VERA_LAYER_1 = $F2000
|
|
|
|
const int24 VERA_LAYER_2 = $F3000
|
|
|
|
const int24 VERA_SPRITE_CTRL = $F4000
|
|
|
|
const int24 VERA_SPRITES = $F5000
|
|
|
|
|
|
|
|
volatile byte vera_addr_hi @ $9f22
|
|
|
|
volatile byte vera_addr_mi @ $9f21
|
|
|
|
volatile byte vera_addr_lo @ $9f20
|
|
|
|
volatile int24 vera_addr @ $9f20
|
|
|
|
|
|
|
|
#else
|
|
|
|
#error Unsupported VERA_VERSION
|
|
|
|
#endif
|
|
|
|
|
2019-09-14 03:34:32 +02:00
|
|
|
volatile byte vera_data1 @ $9f23
|
|
|
|
volatile byte vera_data2 @ $9f24
|
|
|
|
volatile byte vera_ctrl @ $9f25
|
|
|
|
volatile byte vera_ien @ $9f26
|
|
|
|
volatile byte vera_isr @ $9f27
|
|
|
|
|
|
|
|
struct vera_layer_setup {
|
|
|
|
byte ctrl0
|
|
|
|
byte ctrl1
|
|
|
|
word map_base
|
|
|
|
word tile_base
|
|
|
|
word hscroll
|
|
|
|
word vscroll
|
|
|
|
}
|
|
|
|
|
|
|
|
asm void set_vera_layer_internal(pointer.vera_layer_setup ax, byte y) {
|
|
|
|
sta __reg
|
|
|
|
stx __reg+1
|
|
|
|
stz vera_ctrl
|
2019-09-16 22:55:08 +02:00
|
|
|
#if VERA_VERSION == 7
|
2019-09-14 03:34:32 +02:00
|
|
|
lda $14
|
|
|
|
sta vera_addr_hi
|
|
|
|
stz vera_addr_mi
|
|
|
|
sty vera_addr_lo
|
2019-09-16 22:55:08 +02:00
|
|
|
#elseif VERA_VERSION == 8
|
|
|
|
lda $1F
|
|
|
|
sta vera_addr_hi
|
|
|
|
sty vera_addr_mi
|
|
|
|
stz vera_addr_lo
|
|
|
|
#else
|
|
|
|
#error Unsupported VERA_VERSION
|
|
|
|
#endif
|
2019-09-14 03:34:32 +02:00
|
|
|
ldy #0
|
|
|
|
__set_layer_internal_loop:
|
|
|
|
lda (__reg),y
|
|
|
|
sta vera_data1
|
|
|
|
iny
|
|
|
|
cpy #sizeof(vera_layer_setup)
|
|
|
|
bne __set_layer_internal_loop
|
|
|
|
? rts
|
|
|
|
}
|
|
|
|
|
2019-09-16 22:55:08 +02:00
|
|
|
asm void set_vera_layer1(pointer.vera_layer_setup ax) {
|
|
|
|
#if VERA_VERSION == 7
|
2019-09-14 03:34:32 +02:00
|
|
|
? ldy #0
|
2019-09-16 22:55:08 +02:00
|
|
|
#elseif VERA_VERSION == 8
|
|
|
|
? ldy #$20
|
|
|
|
#else
|
|
|
|
#error Unsupported VERA_VERSION
|
|
|
|
#endif
|
2019-09-14 03:34:32 +02:00
|
|
|
? jmp set_vera_layer_internal
|
|
|
|
}
|
|
|
|
|
2019-09-16 22:55:08 +02:00
|
|
|
asm void set_vera_layer2(pointer.vera_layer_setup ax) {
|
|
|
|
#if VERA_VERSION == 7
|
|
|
|
? ldy #$10
|
|
|
|
#elseif VERA_VERSION == 8
|
|
|
|
? ldy #$30
|
|
|
|
#else
|
|
|
|
#error Unsupported VERA_VERSION
|
|
|
|
#endif
|
2019-09-14 03:34:32 +02:00
|
|
|
? jmp set_vera_layer_internal
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void vera_poke(int24 address, byte value) {
|
|
|
|
vera_addr_lo = address.b0
|
|
|
|
vera_addr_mi = address.b1
|
|
|
|
vera_addr_hi = address.b2
|
|
|
|
vera_ctrl = 0
|
|
|
|
vera_data1 = value
|
|
|
|
}
|
|
|
|
|
2019-10-20 15:39:34 +10:00
|
|
|
inline byte vera_peek(int24 address) {
|
|
|
|
vera_addr_lo = address.b0
|
|
|
|
vera_addr_mi = address.b1
|
|
|
|
vera_addr_hi = address.b2
|
|
|
|
vera_ctrl = 0
|
|
|
|
return vera_data1
|
|
|
|
}
|
|
|
|
|
2019-09-14 03:34:32 +02:00
|
|
|
inline void vera_fill(int24 address, byte value, word size) {
|
|
|
|
word i
|
|
|
|
vera_addr_lo = address.b0
|
|
|
|
vera_addr_mi = address.b1
|
|
|
|
vera_addr_hi = address.b2 | $10
|
|
|
|
vera_ctrl = 0
|
|
|
|
for i,0,paralleluntil,size {
|
|
|
|
vera_data1 = value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void vera_upload_large(int24 address, pointer source, word size) {
|
|
|
|
word i
|
|
|
|
vera_ctrl = 0
|
|
|
|
vera_addr_lo = address.b0
|
|
|
|
vera_addr_mi = address.b1
|
|
|
|
vera_addr_hi = address.b2 | $10
|
|
|
|
for i,0,paralleluntil,size {
|
|
|
|
vera_data1 = source[i]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void vera_upload(int24 address, pointer source, byte size) {
|
|
|
|
byte i
|
|
|
|
vera_ctrl = 0
|
|
|
|
vera_addr_lo = address.b0
|
|
|
|
vera_addr_mi = address.b1
|
|
|
|
vera_addr_hi = address.b2 | $10
|
|
|
|
asm {
|
|
|
|
? ldy #0
|
|
|
|
__vera_upload_loop:
|
2019-10-23 11:02:44 +02:00
|
|
|
? lda (source),y
|
2019-09-16 22:55:08 +02:00
|
|
|
! sta vera_data1
|
2019-09-14 03:34:32 +02:00
|
|
|
? iny
|
|
|
|
? cpy size
|
|
|
|
? bne __vera_upload_loop
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct vera_sprite_data {
|
|
|
|
word address
|
|
|
|
word x
|
|
|
|
word y
|
|
|
|
byte ctrl0
|
|
|
|
byte ctrl1
|
|
|
|
}
|
2019-09-16 22:55:08 +02:00
|
|
|
|
|
|
|
inline asm void set_ram_bank(byte a) {
|
|
|
|
! STA $9F61
|
|
|
|
? RTS
|
|
|
|
}
|
|
|
|
|
|
|
|
inline asm void set_rom_bank(byte a) {
|
|
|
|
! STA $9F60
|
|
|
|
? RTS
|
|
|
|
}
|