mirror of
https://github.com/hsoft/collapseos.git
synced 2025-01-12 21:28:06 +11:00
recipes/rc2014/ps2: don't alter SREG in hdlPCINT
This commit is contained in:
parent
e44ebb08b2
commit
360446e731
@ -45,8 +45,8 @@
|
|||||||
; *** Sending to the 595 ***
|
; *** Sending to the 595 ***
|
||||||
;
|
;
|
||||||
; Whenever a scan code is read from the 595, CE goes low and triggers a PCINT
|
; Whenever a scan code is read from the 595, CE goes low and triggers a PCINT
|
||||||
; on PB4. When we get it, we clear the R2 flag to indicate that we're ready to
|
; on PB4. When we get it, we clear the GPIOR0/1 flag to indicate that we're
|
||||||
; send a new scan code to the 595.
|
; ready to send a new scan code to the 595.
|
||||||
;
|
;
|
||||||
; Because that CE flip/flop is real fast (375ns), it requires us to run at 8MHz.
|
; Because that CE flip/flop is real fast (375ns), it requires us to run at 8MHz.
|
||||||
;
|
;
|
||||||
@ -60,8 +60,13 @@
|
|||||||
|
|
||||||
; *** Register Usage ***
|
; *** Register Usage ***
|
||||||
;
|
;
|
||||||
; R2: When set, indicate that the 595 holds a value that hasn't been read by the
|
; GPIOR0 flags:
|
||||||
; z80 yet.
|
; 0 - when set, indicates that the DATA pin was high when we received a
|
||||||
|
; bit through INT0. When we receive a bit, we set flag T to indicate
|
||||||
|
; it.
|
||||||
|
; 1 - When set, indicate that the 595 holds a value that hasn't been read
|
||||||
|
; by the z80 yet.
|
||||||
|
;
|
||||||
; R16: tmp stuff
|
; R16: tmp stuff
|
||||||
; R17: recv buffer. Whenever we receive a bit, we push it in there.
|
; R17: recv buffer. Whenever we receive a bit, we push it in there.
|
||||||
; R18: recv step:
|
; R18: recv step:
|
||||||
@ -70,8 +75,6 @@
|
|||||||
; - 2: awaiting parity bit
|
; - 2: awaiting parity bit
|
||||||
; - 3: awaiting stop bit
|
; - 3: awaiting stop bit
|
||||||
; it reaches 11, we know we're finished with the frame.
|
; it reaches 11, we know we're finished with the frame.
|
||||||
; R19: when set, indicates that the DATA pin was high when we received a bit
|
|
||||||
; through INT0. When we receive a bit, we set flag T to indicate it.
|
|
||||||
; R20: data being sent to the 595
|
; R20: data being sent to the 595
|
||||||
; Y: pointer to the memory location where the next scan code from ps/2 will be
|
; Y: pointer to the memory location where the next scan code from ps/2 will be
|
||||||
; written.
|
; written.
|
||||||
@ -89,21 +92,22 @@
|
|||||||
rjmp hdlINT0
|
rjmp hdlINT0
|
||||||
rjmp hdlPCINT
|
rjmp hdlPCINT
|
||||||
|
|
||||||
; Read DATA and set R19 if high. Then, set flag T.
|
; Read DATA and set GPIOR0/0 if high. Then, set flag T.
|
||||||
; no SREG fiddling because no SREG-modifying instruction
|
; no SREG fiddling because no SREG-modifying instruction
|
||||||
hdlINT0:
|
hdlINT0:
|
||||||
sbic PINB, DATA ; DATA clear? skip next
|
sbic PINB, DATA ; DATA clear? skip next
|
||||||
ser r19
|
sbi GPIOR0, 0
|
||||||
set
|
set
|
||||||
reti
|
reti
|
||||||
|
|
||||||
; Only PB4 is hooked to PCINT and we don't bother checking the value of the PB4
|
; Only PB4 is hooked to PCINT and we don't bother checking the value of the PB4
|
||||||
; pin: things go too fast for this.
|
; pin: things go too fast for this.
|
||||||
|
; no SREG fiddling because no SREG-modifying instruction
|
||||||
hdlPCINT:
|
hdlPCINT:
|
||||||
; SRCLR has been triggered. Let's trigger RCLK too.
|
; SRCLR has been triggered. Let's trigger RCLK too.
|
||||||
sbi PORTB, RCLK
|
sbi PORTB, RCLK
|
||||||
cbi PORTB, RCLK
|
cbi PORTB, RCLK
|
||||||
clr r2 ; 595 is now free
|
cbi GPIOR0, 1 ; 595 is now free
|
||||||
reti
|
reti
|
||||||
|
|
||||||
main:
|
main:
|
||||||
@ -120,9 +124,9 @@ main:
|
|||||||
|
|
||||||
|
|
||||||
; init variables
|
; init variables
|
||||||
clr r2
|
|
||||||
clr r19
|
|
||||||
clr r18
|
clr r18
|
||||||
|
out GPIOR0, r18
|
||||||
|
|
||||||
|
|
||||||
; Setup int0/PCINT
|
; Setup int0/PCINT
|
||||||
; INT0, falling edge
|
; INT0, falling edge
|
||||||
@ -156,8 +160,9 @@ loop:
|
|||||||
|
|
||||||
; Process the data bit received in INT0 handler.
|
; Process the data bit received in INT0 handler.
|
||||||
processbit:
|
processbit:
|
||||||
mov r16, r19 ; backup r19 before we reset T
|
in r16, GPIOR0 ; backup GPIOR0 before we reset T
|
||||||
clr r19
|
andi r16, 0x1 ; only keep the first flag
|
||||||
|
cbi GPIOR0, 0
|
||||||
clt ; ready to receive another bit
|
clt ; ready to receive another bit
|
||||||
|
|
||||||
; Which step are we at?
|
; Which step are we at?
|
||||||
@ -210,8 +215,8 @@ processbits2:
|
|||||||
|
|
||||||
; send next scan code in buffer to 595, MSB.
|
; send next scan code in buffer to 595, MSB.
|
||||||
sendTo595:
|
sendTo595:
|
||||||
tst r2
|
sbic GPIOR0, 1
|
||||||
brne loop ; non-zero? 595 is "busy". Don't send.
|
rjmp loop ; flag 1 set? 595 is "busy". Don't send.
|
||||||
; We disable any interrupt handling during this routine. Whatever it
|
; We disable any interrupt handling during this routine. Whatever it
|
||||||
; is, it has no meaning to us at this point in time and processing it
|
; is, it has no meaning to us at this point in time and processing it
|
||||||
; might mess things up.
|
; might mess things up.
|
||||||
@ -246,8 +251,8 @@ sendTo595Loop:
|
|||||||
; release PS/2
|
; release PS/2
|
||||||
cbi DDRB, DATA
|
cbi DDRB, DATA
|
||||||
|
|
||||||
; Set R2 to "595 is busy"
|
; Set GPIOR0/1 to "595 is busy"
|
||||||
inc r2
|
sbi GPIOR0, 1
|
||||||
|
|
||||||
; toggle RCLK
|
; toggle RCLK
|
||||||
sbi PORTB, RCLK
|
sbi PORTB, RCLK
|
||||||
|
Loading…
Reference in New Issue
Block a user