2015-07-12 14:27:24 +02:00
|
|
|
;
|
2015-10-02 13:28:17 -04:00
|
|
|
; PCE definitions. By Groepaz/Hitmen.
|
2015-07-12 14:27:24 +02:00
|
|
|
;
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
; FIXME: Screen dimensions can change according to the selected video mode.
|
2015-08-29 15:58:57 +02:00
|
|
|
screenrows = (224/8)
|
|
|
|
charsperline = 61
|
|
|
|
|
|
|
|
CH_HLINE = 1
|
|
|
|
CH_VLINE = 2
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
; HuC6270 -- Video Display Controller (VDC)
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-08-29 15:58:57 +02:00
|
|
|
VDC_MAWR = 0 ; Memory Address Write Register
|
|
|
|
VDC_MARR = 1 ; Memory Address Read Register
|
2015-11-17 09:14:15 -05:00
|
|
|
VDC_VWR = 2 ; VRAM Write Register
|
|
|
|
VDC_VRR = 2 ; VRAM Read Register
|
2015-09-07 12:55:36 +02:00
|
|
|
VDC_UNK03 = 3 ; (unknown)
|
|
|
|
VDC_UNK04 = 4 ; (unknown)
|
|
|
|
VDC_CR = 5 ; Control Register
|
|
|
|
VDC_RCR = 6 ; Raster Counter Register
|
|
|
|
VDC_BXR = 7 ; Background X-Scroll Register
|
|
|
|
VDC_BYR = 8 ; Background Y-Scroll Register
|
|
|
|
VDC_MWR = 9 ; Memory-access Width Register
|
|
|
|
VDC_HSR = 10 ; Horizontal Sync Register
|
|
|
|
VDC_HDR = 11 ; Horizontal Display Register
|
2015-10-02 13:28:17 -04:00
|
|
|
VDC_VSR = 12 ; Vertical sync Register
|
|
|
|
VDC_VDR = 13 ; Vertical Display register
|
2015-09-07 12:55:36 +02:00
|
|
|
VDC_VCR = 14 ; Vertical display END position register
|
|
|
|
VDC_DCR = 15 ; (DMA) Control Register
|
|
|
|
VDC_SOUR = 16 ; (DMA) Source Register
|
|
|
|
VDC_DESR = 17 ; (DMA) Destination Register
|
|
|
|
VDC_LENR = 18 ; (DMA) Length Register
|
|
|
|
VDC_SATB = 19 ; Sprite Attribute Table
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-07-15 13:18:12 +02:00
|
|
|
; VDC port
|
2015-09-29 12:39:58 -04:00
|
|
|
; Note: The zero-page addressing mode is redirected to page $20.
|
2015-11-17 09:14:15 -05:00
|
|
|
; We avoid it by using mirror locations that are outside of the zero page.
|
2015-07-15 13:18:12 +02:00
|
|
|
|
2015-09-29 12:39:58 -04:00
|
|
|
VDC_CTRL := $0200
|
|
|
|
VDC_DATA_LO := $0202
|
|
|
|
VDC_DATA_HI := $0203
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
; HuC6260 -- Video Color Encoder (VCE)
|
2014-11-29 14:18:48 +01:00
|
|
|
|
|
|
|
; The DAC has a palette of 512 colours.
|
2015-11-17 09:14:15 -05:00
|
|
|
; The bitmap of that data is 0000000gggrrrbbb (Green, Red, Blue).
|
2015-10-02 10:50:22 -04:00
|
|
|
; You can read and write the DAC registers.
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
VCE := $0400 ; base
|
2015-07-14 17:22:47 +02:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
VCE_CTRL := $0400 ; write $00 to reset
|
|
|
|
VCE_ADDR_LO := $0402 ; LSB of byte offset into palette
|
|
|
|
VCE_ADDR_HI := $0403 ; MSB of byte offset into palette
|
|
|
|
VCE_DATA_LO := $0404 ; LSB of 16-bit palette data
|
|
|
|
VCE_DATA_HI := $0405 ; MSB of 16-bit palette data
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-10-02 10:50:22 -04:00
|
|
|
; Programmable Sound Generator (PSG)
|
2015-07-14 17:22:47 +02:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
PSG := $0800 ; base
|
2015-07-14 17:22:47 +02:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
PSG_CHAN_SELECT := $0800
|
|
|
|
PSG_GLOBAL_PAN := $0801
|
|
|
|
PSG_FREQ_LO := $0802
|
|
|
|
PSG_FREQ_HI := $0803
|
|
|
|
PSG_CHAN_CTRL := $0804
|
|
|
|
PSG_CHAN_PAN := $0805
|
|
|
|
PSG_CHAN_DATA := $0806
|
|
|
|
PSG_NOISE := $0807
|
|
|
|
PSG_LFO_FREQ := $0808
|
|
|
|
PSG_LFO_CTRL := $0809
|
2015-09-04 14:14:17 +02:00
|
|
|
|
2015-10-02 10:50:22 -04:00
|
|
|
; Timer
|
2015-07-14 17:22:47 +02:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
TIMER := $0C00 ; base
|
2015-07-14 17:22:47 +02:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
TIMER_COUNT := $0C00
|
|
|
|
TIMER_CTRL := $0C01
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
JOY_CTRL := $1000
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
IRQ_MASK := $1402
|
|
|
|
IRQ_STATUS := $1403
|
2014-11-29 14:18:48 +01:00
|
|
|
|
2015-10-02 13:28:17 -04:00
|
|
|
CDR_MEM_DISABLE := $1803
|
|
|
|
CDR_MEM_ENABLE := $1807
|
2014-11-29 15:35:20 +01:00
|
|
|
|
2015-11-17 09:14:15 -05:00
|
|
|
; Write to a VDC register.
|
|
|
|
.macro VREG arg1, arg2
|
2015-07-12 14:27:24 +02:00
|
|
|
st0 #arg1
|
|
|
|
st1 #<(arg2)
|
|
|
|
st2 #>(arg2)
|
|
|
|
.endmacro
|