2017-12-07 00:23:30 +01:00
|
|
|
// Hardware addresses for C64
|
|
|
|
|
2019-06-26 13:40:33 +02:00
|
|
|
#if not(CBM_64) && not(CBM_64_COMPAT)
|
2018-07-12 18:30:35 +02:00
|
|
|
#warn c64_cia module should be only used on C64-compatible targets
|
|
|
|
#endif
|
|
|
|
|
2017-12-07 00:23:30 +01:00
|
|
|
// CIA1
|
2018-12-16 21:07:04 +01:00
|
|
|
volatile byte cia1_pra @$DC00
|
|
|
|
volatile byte cia1_prb @$DC01
|
2017-12-07 00:23:30 +01:00
|
|
|
byte cia1_ddra @$DC02
|
|
|
|
byte cia1_ddrb @$DC03
|
2018-12-16 21:07:04 +01:00
|
|
|
volatile byte cia2_pra @$DD00
|
|
|
|
volatile byte cia2_prb @$DD01
|
2017-12-07 00:23:30 +01:00
|
|
|
byte cia2_ddra @$DD02
|
|
|
|
byte cia2_ddrb @$DD03
|
|
|
|
|
2018-02-01 22:39:38 +01:00
|
|
|
macro asm void cia_disable_irq() {
|
2018-12-16 21:07:04 +01:00
|
|
|
? LDA #$7f
|
2020-01-05 10:53:51 +08:00
|
|
|
! STA $dc0d
|
|
|
|
! STA $dd0d
|
2018-12-16 21:07:04 +01:00
|
|
|
! LDA $dc0d
|
|
|
|
! LDA $dd0d
|
2017-12-07 00:23:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-02-01 22:39:38 +01:00
|
|
|
macro void vic_bank_0000() {
|
|
|
|
cia2_ddra = 3
|
|
|
|
cia2_pra = 3
|
2017-12-07 00:23:30 +01:00
|
|
|
}
|
|
|
|
|
2018-02-01 22:39:38 +01:00
|
|
|
macro void vic_bank_4000() {
|
|
|
|
cia2_ddra = 3
|
|
|
|
cia2_pra = 2
|
2017-12-07 00:23:30 +01:00
|
|
|
}
|
|
|
|
|
2018-02-01 22:39:38 +01:00
|
|
|
macro void vic_bank_8000() {
|
|
|
|
cia2_ddra = 3
|
|
|
|
cia2_pra = 1
|
2017-12-07 00:23:30 +01:00
|
|
|
}
|
|
|
|
|
2018-02-01 22:39:38 +01:00
|
|
|
macro void vic_bank_C000() {
|
|
|
|
cia2_ddra = 3
|
|
|
|
cia2_pra = 0
|
2018-07-12 18:30:35 +02:00
|
|
|
}
|