2004-10-08 18:14:19 +00:00
|
|
|
; Lynx system hardware includes
|
|
|
|
; Shawn Jefferson
|
|
|
|
; June 18th, 2004
|
|
|
|
;
|
|
|
|
; Reference:
|
|
|
|
; Bastian Schick's Lynx Documentation
|
2016-04-12 23:58:30 +02:00
|
|
|
; http://www.geocities.ws/SiliconValley/Byte/4242/lynx/
|
2004-10-08 18:14:19 +00:00
|
|
|
;
|
|
|
|
|
|
|
|
; ***
|
|
|
|
; *** Suzy Addresses
|
|
|
|
; ***
|
|
|
|
|
|
|
|
; Sprite Control Block
|
|
|
|
|
|
|
|
TMPADRL = $FC00
|
|
|
|
TMPADRH = $FC01
|
|
|
|
TILTACUML = $FC02
|
|
|
|
TILTACUMH = $FC03
|
|
|
|
HOFFL = $FC04
|
|
|
|
HOFFH = $FC05
|
|
|
|
VOFFL = $FC06
|
|
|
|
VOFFH = $FC07
|
|
|
|
VIDBASL = $FC08
|
|
|
|
VIDBASH = $FC09
|
|
|
|
COLLBASL = $FC0A
|
|
|
|
COLLBASH = $FC0B
|
|
|
|
VIDADRL = $FC0C
|
|
|
|
VIDADRH = $FC0D
|
|
|
|
COLLADRL = $FC0E
|
|
|
|
COLLADRH = $FC0F
|
|
|
|
SCBNEXTL = $FC10
|
|
|
|
SCBNEXTH = $FC11
|
|
|
|
SPRDLINEL = $FC12
|
|
|
|
SPRDLINEH = $FC13
|
|
|
|
HPOSSTRTL = $FC14
|
|
|
|
HPOSSTRTH = $FC15
|
|
|
|
VPOSSTRTL = $FC16
|
|
|
|
VPOSSTRTH = $FC17
|
|
|
|
SPRHSIZL = $FC18
|
|
|
|
SPRHSIZH = $FC19
|
|
|
|
SPRVSIZL = $FC1A
|
|
|
|
SPRVSIZH = $FC1B
|
|
|
|
STRETCHL = $FC1C
|
|
|
|
STRETCHH = $FC1D
|
|
|
|
TILTL = $FC1E
|
|
|
|
TILTH = $FC1F
|
|
|
|
SPRDOFFL = $FC20
|
|
|
|
SPRDOFFH = $FC21
|
|
|
|
SPRVPOSL = $FC22
|
|
|
|
SPRVPOSH = $FC23
|
|
|
|
COLLOFFL = $FC24
|
|
|
|
COLLOFFH = $FC25
|
|
|
|
VSIZACUML = $FC26
|
|
|
|
VSIZACUMH = $FC27
|
|
|
|
HSIZOFFL = $FC28
|
|
|
|
HSIZOFFH = $FC29
|
|
|
|
VSIZOFFL = $FC2A
|
|
|
|
VSIZOFFH = $FC2B
|
|
|
|
SCBADRL = $FC2C
|
|
|
|
SCBADRH = $FC2D
|
|
|
|
PROCADRL = $FC2E
|
|
|
|
PROCADRH = $FC2F
|
|
|
|
|
|
|
|
; Suzy Math
|
|
|
|
|
|
|
|
MATHD = $FC52
|
|
|
|
MATHC = $FC53
|
|
|
|
MATHB = $FC54
|
|
|
|
MATHA = $FC55
|
|
|
|
MATHP = $FC56
|
|
|
|
MATHN = $FC57
|
|
|
|
MATHH = $FC60
|
|
|
|
MATHG = $FC61
|
|
|
|
MATHF = $FC62
|
|
|
|
MATHE = $FC63
|
|
|
|
MATHM = $FC6C
|
|
|
|
MATHL = $FC6D
|
|
|
|
MATHK = $FC6E
|
|
|
|
MATHJ = $FC6F
|
|
|
|
|
|
|
|
; Suzy Misc
|
|
|
|
|
2023-12-29 22:46:15 +01:00
|
|
|
SPRCTL0 = $FC80
|
2023-12-29 22:37:18 +01:00
|
|
|
; Sprite bits-per-pixel definitions
|
2023-12-29 22:46:15 +01:00
|
|
|
BPP_MASK = %11000000 ; Mask for settings bits per pixel
|
|
|
|
BPP_1 = %00000000
|
|
|
|
BPP_2 = %01000000
|
|
|
|
BPP_3 = %10000000
|
|
|
|
BPP_4 = %11000000
|
2023-12-29 22:37:18 +01:00
|
|
|
; More sprite control 0 bit definitions
|
2023-12-29 22:46:15 +01:00
|
|
|
HFLIP = %00100000
|
|
|
|
VFLIP = %00010000
|
2023-12-29 22:37:18 +01:00
|
|
|
; Sprite types - redefined to reflect the reality caused by the shadow error
|
2023-12-29 22:46:15 +01:00
|
|
|
TYPE_SHADOW = %00000111
|
|
|
|
TYPE_XOR = %00000110
|
2023-12-29 22:37:18 +01:00
|
|
|
TYPE_NONCOLL = %00000101 ; Non-colliding
|
2023-12-29 22:48:36 +01:00
|
|
|
TYPE_NORMAL = %00000100
|
|
|
|
TYPE_BOUNDARY = %00000011
|
2023-12-29 22:37:18 +01:00
|
|
|
TYPE_BSHADOW = %00000010 ; Background shadow
|
|
|
|
TYPE_BACKNONCOLL = %00000001 ; Background non-colliding
|
2023-12-29 22:48:36 +01:00
|
|
|
TYPE_BACKGROUND = %00000000
|
2023-12-29 22:37:18 +01:00
|
|
|
|
2023-12-29 22:46:15 +01:00
|
|
|
SPRCTL1 = $FC81
|
|
|
|
LITERAL = %10000000
|
|
|
|
PACKED = %00000000
|
2023-12-29 22:48:36 +01:00
|
|
|
ALGO3 = %01000000 ; Broken, do not set this bit!
|
2023-12-29 22:37:18 +01:00
|
|
|
; Sprite reload mask definitions
|
2023-12-29 22:46:15 +01:00
|
|
|
RELOAD_MASK = %00110000
|
2023-12-29 22:48:36 +01:00
|
|
|
RENONE = %00000000 ; Reload nothing
|
|
|
|
REHV = %00010000 ; Reload hsize, vsize
|
|
|
|
REHVS = %00100000 ; Reload hsize, vsize, stretch
|
|
|
|
REHVST = %00110000 ; Reload hsize, vsize, stretch, tilt
|
2023-12-29 22:37:18 +01:00
|
|
|
; More sprite control 1 bit definitions
|
2023-12-29 22:46:15 +01:00
|
|
|
REUSEPAL = %00001000
|
|
|
|
SKIP = %00000100
|
|
|
|
DRAWUP = %00000010
|
|
|
|
DRAWLEFT = %00000001
|
2023-12-29 22:37:18 +01:00
|
|
|
|
2004-10-08 18:14:19 +00:00
|
|
|
SPRCOLL = $FC82
|
|
|
|
SPRINIT = $FC83
|
|
|
|
SUZYHREV = $FC88
|
|
|
|
SUZYSREV = $FC89
|
|
|
|
SUZYBUSEN = $FC90
|
|
|
|
SPRGO = $FC91
|
|
|
|
SPRSYS = $FC92
|
|
|
|
JOYSTICK = $FCB0
|
|
|
|
SWITCHES = $FCB1
|
|
|
|
RCART0 = $FCB2
|
|
|
|
RCART1 = $FCB3
|
|
|
|
LEDS = $FCC0
|
|
|
|
PARSTATUS = $FCC2
|
|
|
|
PARDATA = $FCC3
|
|
|
|
HOWIE = $FCC4
|
|
|
|
|
|
|
|
|
|
|
|
; ***
|
|
|
|
; *** Mikey Addresses
|
|
|
|
; ***
|
|
|
|
|
|
|
|
; Mikey Timers
|
|
|
|
|
|
|
|
TIMER0 = $FD00
|
|
|
|
TIMER1 = $FD04
|
|
|
|
TIMER2 = $FD08
|
|
|
|
TIMER3 = $FD0C
|
|
|
|
TIMER4 = $FD10
|
|
|
|
TIMER5 = $FD14
|
|
|
|
TIMER6 = $FD18
|
|
|
|
TIMER7 = $FD1C
|
|
|
|
HTIMER = $FD00 ; horizontal line timer (timer 0)
|
|
|
|
VTIMER = $FD08 ; vertical blank timer (timer 2)
|
2012-12-11 05:56:59 +00:00
|
|
|
STIMER = $FD1C ; sound timer (timer 7)
|
2004-10-08 18:14:19 +00:00
|
|
|
|
|
|
|
HTIMBKUP = $FD00 ; horizontal line timer (timer 0)
|
|
|
|
HTIMCTLA = $FD01
|
|
|
|
HTIMCNT = $FD02
|
|
|
|
HTIMCTLB = $FD03
|
|
|
|
VTIMBKUP = $FD08 ; vertical blank timer (timer 2)
|
|
|
|
VTIMCTLA = $FD09
|
|
|
|
VTIMCNT = $FD0A
|
|
|
|
VTIMCTLB = $FD0B
|
|
|
|
BAUDBKUP = $FD10 ; serial timer (timer 4)
|
2012-12-11 05:56:59 +00:00
|
|
|
STIMBKUP = $FD1C ; sound timer (timer 7)
|
|
|
|
STIMCTLA = $FD1D
|
|
|
|
STIMCNT = $FD1E
|
|
|
|
STIMCTLB = $FD1F
|
2004-10-08 18:14:19 +00:00
|
|
|
|
|
|
|
TIM0BKUP = $FD00
|
|
|
|
TIM0CTLA = $FD01
|
|
|
|
TIM0CNT = $FD02
|
2022-04-17 16:04:58 +02:00
|
|
|
TIM0CTLB = $FD03
|
2004-10-08 18:14:19 +00:00
|
|
|
TIM1BKUP = $FD04
|
|
|
|
TIM1CTLA = $FD05
|
|
|
|
TIM1CNT = $FD06
|
2022-04-17 16:04:58 +02:00
|
|
|
TIM1CTLB = $FD07
|
2004-10-08 18:14:19 +00:00
|
|
|
TIM2BKUP = $FD08
|
|
|
|
TIM2CTLA = $FD09
|
|
|
|
TIM2CNT = $FD0A
|
2022-04-17 16:04:58 +02:00
|
|
|
TIM2CTLB = $FD0B
|
2004-10-08 18:14:19 +00:00
|
|
|
TIM3BKUP = $FD0C
|
|
|
|
TIM3CTLA = $FD0D
|
|
|
|
TIM3CNT = $FD0E
|
2022-04-17 16:04:58 +02:00
|
|
|
TIM3CTLB = $FD0F
|
2004-10-08 18:14:19 +00:00
|
|
|
TIM4BKUP = $FD10
|
|
|
|
TIM4CTLA = $FD11
|
|
|
|
TIM4CNT = $FD12
|
2022-04-17 16:04:58 +02:00
|
|
|
TIM4CTLB = $FD13
|
2004-10-08 18:14:19 +00:00
|
|
|
TIM5BKUP = $FD14
|
|
|
|
TIM5CTLA = $FD15
|
|
|
|
TIM5CNT = $FD16
|
2022-04-17 16:04:58 +02:00
|
|
|
TIM5CTLB = $FD17
|
2004-10-08 18:14:19 +00:00
|
|
|
TIM6BKUP = $FD18
|
|
|
|
TIM6CTLA = $FD19
|
|
|
|
TIM6CNT = $FD1A
|
2022-04-17 16:04:58 +02:00
|
|
|
TIM6CTLB = $FD1B
|
2004-10-08 18:14:19 +00:00
|
|
|
TIM7BKUP = $FD1C
|
|
|
|
TIM7CTLA = $FD1D
|
|
|
|
TIM7CNT = $FD1E
|
2022-04-17 16:04:58 +02:00
|
|
|
TIM7CTLB = $FD1F
|
2004-10-08 18:14:19 +00:00
|
|
|
|
|
|
|
; Mikey Audio
|
|
|
|
|
|
|
|
AUDIO0 = $FD20 ; audio channel 0
|
|
|
|
AUDIO1 = $FD28 ; audio channel 1
|
|
|
|
AUDIO2 = $FD30 ; audio channel 2
|
|
|
|
AUDIO3 = $FD38 ; audio channel 3
|
|
|
|
|
|
|
|
AUD0VOL = $FD20
|
|
|
|
AUD0FEED = $FD21
|
|
|
|
AUD0OUT = $FD22
|
|
|
|
AUD0SHIFT = $FD23
|
|
|
|
AUD0BKUP = $FD24
|
|
|
|
AUD0CTLA = $FD25
|
|
|
|
AUD0CNT = $FD26
|
|
|
|
AUD0CTLB = $FD27
|
|
|
|
AUD1VOL = $FD28
|
|
|
|
AUD1FEED = $FD29
|
|
|
|
AUD1OUT = $FD2A
|
|
|
|
AUD1SHIFT = $FD2B
|
|
|
|
AUD1BKUP = $FD2C
|
|
|
|
AUD1CTLA = $FD2D
|
|
|
|
AUD1CNT = $FD2E
|
|
|
|
AUD1CTLB = $FD2F
|
|
|
|
AUD2VOL = $FD30
|
|
|
|
AUD2FEED = $FD31
|
|
|
|
AUD2OUT = $FD32
|
|
|
|
AUD2SHIFT = $FD33
|
|
|
|
AUD2BKUP = $FD34
|
|
|
|
AUD2CTLA = $FD35
|
|
|
|
AUD2CNT = $FD36
|
|
|
|
AUD2CTLB = $FD37
|
|
|
|
AUD3VOL = $FD38
|
|
|
|
AUD3FEED = $FD39
|
|
|
|
AUD3OUT = $FD3A
|
|
|
|
AUD3SHIFT = $FD3B
|
|
|
|
AUD3BKUP = $FD3C
|
|
|
|
AUD3CTLA = $FD3D
|
|
|
|
AUD3CNT = $FD3E
|
|
|
|
AUD3CTLB = $FD3F
|
|
|
|
MSTEREO = $FD50
|
|
|
|
|
|
|
|
; Mikey Misc
|
|
|
|
|
2009-09-20 14:22:04 +00:00
|
|
|
; Interrupt bits in INTRST and INTSET
|
|
|
|
TIMER0_INTERRUPT = $01
|
|
|
|
TIMER1_INTERRUPT = $02
|
|
|
|
TIMER2_INTERRUPT = $04
|
|
|
|
TIMER3_INTERRUPT = $08
|
|
|
|
TIMER4_INTERRUPT = $10
|
|
|
|
TIMER5_INTERRUPT = $20
|
|
|
|
TIMER6_INTERRUPT = $40
|
|
|
|
TIMER7_INTERRUPT = $80
|
|
|
|
|
|
|
|
HBL_INTERRUPT = TIMER0_INTERRUPT
|
|
|
|
VBL_INTERRUPT = TIMER2_INTERRUPT
|
|
|
|
SERIAL_INTERRUPT = TIMER4_INTERRUPT
|
2012-12-11 05:56:59 +00:00
|
|
|
SND_INTERRUPT = TIMER7_INTERRUPT
|
2009-09-20 14:22:04 +00:00
|
|
|
|
2004-10-08 18:14:19 +00:00
|
|
|
INTRST = $FD80
|
|
|
|
INTSET = $FD81
|
2024-02-11 15:33:22 +00:00
|
|
|
|
2004-10-08 18:14:19 +00:00
|
|
|
MAGRDY0 = $FD84
|
|
|
|
MAGRDY1 = $FD85
|
|
|
|
AUDIN = $FD86
|
|
|
|
SYSCTL1 = $FD87
|
|
|
|
MIKEYHREV = $FD88
|
|
|
|
MIKEYSREV = $FD89
|
2024-02-09 00:09:16 +00:00
|
|
|
|
2024-02-11 15:33:22 +00:00
|
|
|
IODIR = $FD8A
|
|
|
|
IODAT = $FD8B
|
|
|
|
; IODIR and IODAT bit definitions
|
|
|
|
AUDIN_BIT = $10 ; Note that there is also the address AUDIN
|
|
|
|
READ_ENABLE = $10 ; Same bit for AUDIN_BIT
|
|
|
|
RESTLESS = $08
|
|
|
|
NOEXP = $04 ; If set, redeye is not connected
|
|
|
|
CART_ADDR_DATA = $02
|
|
|
|
CART_POWER_OFF = $02 ; Same bit for CART_ADDR_DATA
|
|
|
|
EXTERNAL_POWER = $01
|
|
|
|
|
|
|
|
SERCTL = $FD8C
|
2024-02-09 00:09:16 +00:00
|
|
|
; SERCTL bit definitions for write operations
|
|
|
|
TXINTEN = $80
|
|
|
|
RXINTEN = $40
|
|
|
|
PAREN = $10
|
|
|
|
RESETERR = $08
|
|
|
|
TXOPEN = $04
|
|
|
|
TXBRK = $02
|
|
|
|
PAREVEN = $01
|
|
|
|
; SERCTL bit definitions for read operations
|
|
|
|
TXRDY = $80
|
|
|
|
RXRDY = $40
|
|
|
|
TXEMPTY = $20
|
|
|
|
PARERR = $10
|
|
|
|
OVERRUN = $08
|
|
|
|
FRAMERR = $04
|
|
|
|
RXBRK = $02
|
|
|
|
PARBIT = $01
|
|
|
|
|
2004-10-08 18:14:19 +00:00
|
|
|
SERDAT = $FD8D
|
|
|
|
SDONEACK = $FD90
|
|
|
|
CPUSLEEP = $FD91
|
|
|
|
DISPCTL = $FD92
|
|
|
|
PBKUP = $FD93
|
|
|
|
DISPADRL = $FD94
|
|
|
|
DISPADRH = $FD95
|
|
|
|
MTEST0 = $FD9C
|
|
|
|
MTEST1 = $FD9D
|
|
|
|
MTEST2 = $FD9E
|
|
|
|
PALETTE = $FDA0 ; hardware rgb palette
|
|
|
|
GCOLMAP = $FDA0 ; hardware rgb palette (green)
|
|
|
|
RBCOLMAP = $FDB0 ; hardware rgb palette (red-blue)
|
|
|
|
|
|
|
|
|
|
|
|
; ***
|
|
|
|
; *** Misc Hardware + 6502 vectors
|
|
|
|
; ***
|
|
|
|
|
|
|
|
MAPCTL = $FFF9
|
|
|
|
VECTORS = $FFFB
|
|
|
|
INTVECTL = $FFFE
|
|
|
|
INTVECTH = $FFFF
|
|
|
|
RSTVECTL = $FFFC
|
|
|
|
RSTVECTH = $FFFD
|
|
|
|
NMIVECTL = $FFFA
|
|
|
|
NMIVECTH = $FFFB
|
|
|
|
|