From d78e451d6bb81823c77d421e327a738bc54dc943 Mon Sep 17 00:00:00 2001 From: Joe Zhao Date: Fri, 16 May 2014 16:23:50 +0800 Subject: Added Machine State --- rs422lib/rsbus.c | 59 +++++++++++++++++++++++++++++++++++++------------------- 1 file changed, 39 insertions(+), 20 deletions(-) (limited to 'rs422lib/rsbus.c') diff --git a/rs422lib/rsbus.c b/rs422lib/rsbus.c index 2e63594..4c0fcb2 100644 --- a/rs422lib/rsbus.c +++ b/rs422lib/rsbus.c @@ -13,14 +13,15 @@ unsigned char rs_rxbuf[RSMAX]; unsigned char len; unsigned char pch; -unsigned char ret; rshdlr rxhdlr; enum rs_stat{REST,ST,ADDR,READ,DISCARD,ED,DED}; enum rs_stat rs_st=REST; -unsigned char rs_tx[15]={STBIT1,0,RSADDR,MACTYPE}; -unsigned char tx_len; -unsigned char tx_pos; +unsigned char rs_tx[20]={STBIT1,0,RSADDR,MACTYPE}; +volatile unsigned char tx_len; +volatile unsigned char tx_pos=255; + +volatile unsigned char mac_stat[4]={0,0,0,0}; #pragma vector=USCIAB0TX_VECTOR __interrupt void USCI0TX_ISR(void) @@ -29,16 +30,39 @@ __interrupt void USCI0TX_ISR(void) { UC0IE &= ~UCA0TXIE; // Disable USCI_A0 TX interrupt RSOUT &= ~(RSPIN); + tx_pos = 255; } else UCA0TXBUF = rs_tx[tx_pos++]; // TX next character } +#pragma FUNC_ALWAYS_INLINE(rsbus_w_irq) +static __inline void rsbus_w_irq(unsigned char* buf,unsigned int len) +{ + unsigned int i; + if (tx_pos < tx_len) // This shouldn't happen + return; // Race condition + RSOUT |= RSPIN; + tx_len=len+7; + unsigned int parity=MACTYPE^RSADDR; + rs_tx[1]=0; // Useless addr spec + rs_tx[2]=RSADDR; + rs_tx[3]=MACTYPE; + for (i=0;i wait unsigned int i; - if (len>4) + if (len>14) return; RSOUT |= RSPIN; tx_len=len+7; unsigned int parity=addr^MACTYPE^RSADDR; - rs_tx[1]=addr; + rs_tx[1]=addr; // Useless addr spec + rs_tx[2]=RSADDR; + rs_tx[3]=MACTYPE; for (i=0;i