2020-04-05 07:07:35 +10:00
|
|
|
( Save ACIA conf )
|
2020-04-05 01:31:22 +11:00
|
|
|
ACIA_CTL
|
|
|
|
: ACIA_CTL [ LITN ] ;
|
|
|
|
ACIA_IO
|
|
|
|
: ACIA_IO [ LITN ] ;
|
2020-04-12 05:11:36 +10:00
|
|
|
ACIA_MEM
|
|
|
|
: ACIA_MEM [ LITN ] ;
|
|
|
|
( Memory layout
|
|
|
|
+0 ACIAR>
|
|
|
|
+2 ACIAW>
|
|
|
|
+4 ACIA(
|
|
|
|
+6 ACIA)
|
|
|
|
)
|
2020-04-05 01:31:22 +11:00
|
|
|
|
2020-04-12 05:11:36 +10:00
|
|
|
(xentry) ~ACIA
|
2020-04-05 01:31:22 +11:00
|
|
|
AF PUSHqq,
|
|
|
|
HL PUSHqq,
|
|
|
|
DE PUSHqq,
|
|
|
|
|
|
|
|
( Read our character from ACIA into our BUFIDX )
|
|
|
|
ACIA_CTL INAn,
|
|
|
|
0x01 ANDn, ( is ACIA rcv buf full? )
|
2020-04-16 22:18:55 +10:00
|
|
|
IFNZ,
|
|
|
|
( correct interrupt cause )
|
|
|
|
( +2 == ACIAW> )
|
|
|
|
ACIA_MEM 2+ LDHL(nn),
|
|
|
|
( is it == to ACIAR>? )
|
|
|
|
( +0 == ACIAR> )
|
|
|
|
DE ACIA_MEM LDdd(nn),
|
|
|
|
( carry cleared from ANDn above )
|
|
|
|
DE SBCHLss,
|
|
|
|
IFNZ, ( buffer full? )
|
|
|
|
( no, continue )
|
|
|
|
DE ADDHLss, ( restore ACIAW> )
|
|
|
|
( buffer not full, let's write )
|
|
|
|
ACIA_IO INAn,
|
|
|
|
(HL) A LDrr,
|
2020-04-05 01:31:22 +11:00
|
|
|
|
2020-04-16 22:18:55 +10:00
|
|
|
( advance W> )
|
|
|
|
HL INCss,
|
|
|
|
( +2 == ACIAW> )
|
|
|
|
ACIA_MEM 2+ LD(nn)HL,
|
|
|
|
( +6 == ACIA) )
|
|
|
|
DE ACIA_MEM 6 + LDdd(nn),
|
|
|
|
DE SUBHLss,
|
|
|
|
IFZ, ( end of buffer reached? )
|
|
|
|
( yes )
|
|
|
|
( +4 == ACIA( )
|
|
|
|
ACIA_MEM 4 + LDHL(nn),
|
|
|
|
( +2 == ACIAW> )
|
|
|
|
ACIA_MEM 2+ LD(nn)HL,
|
|
|
|
THEN,
|
|
|
|
THEN,
|
|
|
|
THEN,
|
2020-04-05 01:31:22 +11:00
|
|
|
|
|
|
|
DE POPqq,
|
|
|
|
HL POPqq,
|
|
|
|
AF POPqq,
|
|
|
|
EI,
|
|
|
|
RETI,
|