@ -30,27 +30,16 @@
this software .
this software .
*/
*/
# include "SoftUART.h"
/** \file
*
volatile bool srx_done ;
* Software UART for both data transmission and reception . This
volatile uint8_t stx_count ;
* code continuously monitors the ring buffers set up by the main
static uint8_t srx_data , srx_mask , srx_tmp , stx_data ;
* project source file and reads / writes data as it becomes available .
*/
void SoftUART_TxByte ( uint8_t Byte )
{
while ( stx_count ) ;
stx_data = ~ Byte ;
# include "SoftUART.h"
stx_count = 10 ;
}
uint8_t SoftUART_RxByte ( void )
static uint8_t TX_BitsRemaining , TX_Data , RX_BitMask , RX_Data ;
{
while ( ! ( srx_done ) ) ;
srx_done = false ;
return srx_data ;
}
void SoftUART_Init ( void )
void SoftUART_Init ( void )
{
{
@ -61,8 +50,7 @@ void SoftUART_Init(void)
EICRA = ( 1 < < ISC01 ) ; // -ve edge
EICRA = ( 1 < < ISC01 ) ; // -ve edge
EIMSK = ( 1 < < INT0 ) ; // enable INT0 interrupt
EIMSK = ( 1 < < INT0 ) ; // enable INT0 interrupt
stx_count = 0 ; // nothing to send
TX_BitsRemaining = 0 ; // nothing to send
srx_done = false ; // nothing received
STXPORT | = ( 1 < < STX ) ; // TX output
STXPORT | = ( 1 < < STX ) ; // TX output
STXDDR | = ( 1 < < STX ) ; // TX output
STXDDR | = ( 1 < < STX ) ; // TX output
SRXPORT | = ( 1 < < SRX ) ; // pullup on INT0
SRXPORT | = ( 1 < < SRX ) ; // pullup on INT0
@ -73,8 +61,8 @@ ISR(INT0_vect)
{
{
OCR2A = TCNT2 + ( BIT_TIME / 8 * 3 / 2 ) ; // scan 1.5 bits after start
OCR2A = TCNT2 + ( BIT_TIME / 8 * 3 / 2 ) ; // scan 1.5 bits after start
srx_tmp = 0 ; // clear bit storage
RX_Data = 0 ; // clear bit storage
srx_mask = 1 ; // bit mask
RX_BitMask = ( 1 < < 0 ) ; // bit mask
TIFR2 = ( 1 < < OCF2A ) ; // clear pending interrupt
TIFR2 = ( 1 < < OCF2A ) ; // clear pending interrupt
@ -88,19 +76,19 @@ ISR(INT0_vect)
/* ISR to manage the reception of bits to the transmitter. */
/* ISR to manage the reception of bits to the transmitter. */
ISR ( TIMER2_COMPA_vect )
ISR ( TIMER2_COMPA_vect )
{
{
if ( srx_m ask)
if ( RX_BitM ask)
{
{
if ( SRXPIN & ( 1 < < SRX ) )
if ( SRXPIN & ( 1 < < SRX ) )
srx_tmp | = srx_m ask;
RX_Data | = RX_BitM ask;
srx_m ask < < = 1 ;
RX_BitM ask < < = 1 ;
OCR2A + = BIT_TIME / 8 ; // next bit slice
OCR2A + = BIT_TIME / 8 ; // next bit slice
}
}
else
else
{
{
srx_done = true ; // mark rx data valid
RingBuffer_Insert ( & UARTtoUSB_Buffer , RX_Data ) ;
srx_data = srx_tmp ; // store rx data
TIMSK2 = ( 1 < < OCIE2B ) ; // enable tx and wait for start
TIMSK2 = ( 1 < < OCIE2B ) ; // enable tx and wait for start
EIMSK | = ( 1 < < INT0 ) ; // enable START irq
EIMSK | = ( 1 < < INT0 ) ; // enable START irq
EIFR = ( 1 < < INTF0 ) ; // clear any pending
EIFR = ( 1 < < INTF0 ) ; // clear any pending
@ -112,20 +100,25 @@ ISR(TIMER2_COMPB_vect)
{
{
OCR2B + = BIT_TIME / 8 ; // next bit slice
OCR2B + = BIT_TIME / 8 ; // next bit slice
if ( stx_count )
if ( TX_BitsRemaining )
{
{
if ( - - stx_count ! = 9 ) // no start bit
if ( - - TX_BitsRemaining ! = 9 ) // no start bit
{
{
if ( ! ( stx_data & 1 ) ) // test inverted data
if ( TX_Data & ( 1 < < 0 ) ) // test inverted data
TCCR2A = ( 1 < < COM2B1 ) | ( 1 < < COM2B0 ) ;
else
TCCR2A = ( 1 < < COM2B1 ) ;
TCCR2A = ( 1 < < COM2B1 ) ;
else
TCCR2A = ( 1 < < COM2B1 ) | ( 1 < < COM2B0 ) ;
stx_data > > = 1 ; // shift zero in from left
TX_D ata > > = 1 ; // shift zero in from left
}
}
else
else
{
{
TCCR2A = ( 1 < < COM2B1 ) ; // START bit
TCCR2A = ( 1 < < COM2B1 ) ; // START bit
}
}
}
}
else if ( USBtoUART_Buffer . Count )
{
TX_Data = ~ RingBuffer_Remove ( & USBtoUART_Buffer ) ;
TX_BitsRemaining = 10 ;
}
}
}