mirror of
https://github.com/mfulz/qmk_firmware.git
synced 2025-06-26 16:45:18 +02:00
Add glitch protection to the software UART in the XPLAINBridge project code, so that very short glitches on the RX line don't cause a frame reception to occur.
This commit is contained in:
parent
229935184b
commit
3fd246041b
@ -76,15 +76,21 @@ void SoftUART_Init(void)
|
|||||||
/** ISR to detect the start of a bit being sent to the software UART. */
|
/** ISR to detect the start of a bit being sent to the software UART. */
|
||||||
ISR(INT0_vect, ISR_BLOCK)
|
ISR(INT0_vect, ISR_BLOCK)
|
||||||
{
|
{
|
||||||
/* Reset and start the reception timer */
|
|
||||||
TCNT1 = 0;
|
|
||||||
TCCR1B = ((1 << CS10) | (1 << WGM12));
|
|
||||||
|
|
||||||
/* Reset the number of reception bits remaining counter */
|
/* Reset the number of reception bits remaining counter */
|
||||||
RX_BitsRemaining = 8;
|
RX_BitsRemaining = 8;
|
||||||
|
|
||||||
|
/* Reset the bit reception timer */
|
||||||
|
TCNT1 = 0;
|
||||||
|
|
||||||
/* Disable start bit detection ISR while the next byte is received */
|
/* Check to see that the pin is still low (prevents glitches from starting a frame reception) */
|
||||||
EIMSK = 0;
|
if (!(SRXPIN & (1 << SRX)))
|
||||||
|
{
|
||||||
|
/* Disable start bit detection ISR while the next byte is received */
|
||||||
|
EIMSK = 0;
|
||||||
|
|
||||||
|
/* Start the reception timer */
|
||||||
|
TCCR1B = ((1 << CS10) | (1 << WGM12));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** ISR to manage the reception of bits to the software UART. */
|
/** ISR to manage the reception of bits to the software UART. */
|
||||||
@ -133,7 +139,7 @@ ISR(TIMER3_COMPA_vect, ISR_NOBLOCK)
|
|||||||
TX_Data >>= 1;
|
TX_Data >>= 1;
|
||||||
TX_BitsRemaining--;
|
TX_BitsRemaining--;
|
||||||
}
|
}
|
||||||
else if (USBtoUART_Buffer.Count)
|
else if (USBtoUART_Buffer.Count && !(RX_BitsRemaining))
|
||||||
{
|
{
|
||||||
/* Start bit - TX line low */
|
/* Start bit - TX line low */
|
||||||
STXPORT &= ~(1 << STX);
|
STXPORT &= ~(1 << STX);
|
||||||
|
@ -180,7 +180,7 @@ void EVENT_USB_Device_ConfigurationChanged(void)
|
|||||||
{
|
{
|
||||||
EndpointConfigSuccess &= CDC_Device_ConfigureEndpoints(&VirtualSerial_CDC_Interface);
|
EndpointConfigSuccess &= CDC_Device_ConfigureEndpoints(&VirtualSerial_CDC_Interface);
|
||||||
|
|
||||||
/* Configure the UART flush timer */
|
/* Configure the UART flush timer - run at FCPU/1024 for maximum interval before overflow */
|
||||||
TCCR0B = ((1 << CS02) | (1 << CS00));
|
TCCR0B = ((1 << CS02) | (1 << CS00));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
Loading…
x
Reference in New Issue
Block a user