mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
1227 lines
38 KiB
Diff
1227 lines
38 KiB
Diff
|
*** stock_iot-lab_M3/openwsn/openserial.c Thu Apr 24 11:01:37 2014
|
||
|
--- riot-openwsn-wip/openwsn/openserial.c Thu Apr 24 16:55:54 2014
|
||
|
***************
|
||
|
*** 15,54 ****
|
||
|
#include "tcpinject.h"
|
||
|
#include "udpinject.h"
|
||
|
#include "openbridge.h"
|
||
|
! #include "leds.h"
|
||
|
#include "schedule.h"
|
||
|
! #include "uart.h"
|
||
|
#include "opentimers.h"
|
||
|
#include "openhdlc.h"
|
||
|
|
||
|
! //=========================== variables =======================================
|
||
|
|
||
|
! typedef struct {
|
||
|
! // admin
|
||
|
! uint8_t mode;
|
||
|
! uint8_t debugPrintCounter;
|
||
|
! // input
|
||
|
! uint8_t reqFrame[1+1+2+1]; // flag (1B), command (2B), CRC (2B), flag (1B)
|
||
|
! uint8_t reqFrameIdx;
|
||
|
! uint8_t lastRxByte;
|
||
|
! bool busyReceiving;
|
||
|
! bool inputEscaping;
|
||
|
! uint16_t inputCrc;
|
||
|
! uint8_t inputBufFill;
|
||
|
! uint8_t inputBuf[SERIAL_INPUT_BUFFER_SIZE];
|
||
|
! // output
|
||
|
! bool outputBufFilled;
|
||
|
! uint16_t outputCrc;
|
||
|
! uint8_t outputBufIdxW;
|
||
|
! uint8_t outputBufIdxR;
|
||
|
! uint8_t outputBuf[SERIAL_OUTPUT_BUFFER_SIZE];
|
||
|
! } openserial_vars_t;
|
||
|
|
||
|
openserial_vars_t openserial_vars;
|
||
|
|
||
|
//=========================== prototypes ======================================
|
||
|
|
||
|
! error_t openserial_printInfoErrorCritical(
|
||
|
char severity,
|
||
|
uint8_t calling_component,
|
||
|
uint8_t error_code,
|
||
|
--- 15,35 ----
|
||
|
#include "tcpinject.h"
|
||
|
#include "udpinject.h"
|
||
|
#include "openbridge.h"
|
||
|
! #include "leds_ow.h"
|
||
|
#include "schedule.h"
|
||
|
! #include "uart_ow.h"
|
||
|
#include "opentimers.h"
|
||
|
#include "openhdlc.h"
|
||
|
|
||
|
! #include <stdio.h>
|
||
|
|
||
|
! //=========================== variables =======================================
|
||
|
|
||
|
openserial_vars_t openserial_vars;
|
||
|
|
||
|
//=========================== prototypes ======================================
|
||
|
|
||
|
! owerror_t openserial_printInfoErrorCritical(
|
||
|
char severity,
|
||
|
uint8_t calling_component,
|
||
|
uint8_t error_code,
|
||
|
***************
|
||
|
*** 56,182 ****
|
||
|
errorparameter_t arg2
|
||
|
);
|
||
|
// HDLC output
|
||
|
! void outputHdlcOpen();
|
||
|
void outputHdlcWrite(uint8_t b);
|
||
|
! void outputHdlcClose();
|
||
|
// HDLC input
|
||
|
! void inputHdlcOpen();
|
||
|
void inputHdlcWrite(uint8_t b);
|
||
|
! void inputHdlcClose();
|
||
|
|
||
|
//=========================== public ==========================================
|
||
|
|
||
|
! void openserial_init() {
|
||
|
! uint16_t crc;
|
||
|
!
|
||
|
! // reset variable
|
||
|
! memset(&openserial_vars,0,sizeof(openserial_vars_t));
|
||
|
!
|
||
|
! // admin
|
||
|
! openserial_vars.mode = MODE_OFF;
|
||
|
! openserial_vars.debugPrintCounter = 0;
|
||
|
!
|
||
|
! // input
|
||
|
! openserial_vars.reqFrame[0] = HDLC_FLAG;
|
||
|
! openserial_vars.reqFrame[1] = SERFRAME_MOTE2PC_REQUEST;
|
||
|
! crc = HDLC_CRCINIT;
|
||
|
! crc = crcIteration(crc,openserial_vars.reqFrame[1]);
|
||
|
! crc = ~crc;
|
||
|
! openserial_vars.reqFrame[2] = (crc>>0)&0xff;
|
||
|
! openserial_vars.reqFrame[3] = (crc>>8)&0xff;
|
||
|
! openserial_vars.reqFrame[4] = HDLC_FLAG;
|
||
|
! openserial_vars.reqFrameIdx = 0;
|
||
|
! openserial_vars.lastRxByte = HDLC_FLAG;
|
||
|
! openserial_vars.busyReceiving = FALSE;
|
||
|
! openserial_vars.inputEscaping = FALSE;
|
||
|
! openserial_vars.inputBufFill = 0;
|
||
|
!
|
||
|
! // ouput
|
||
|
! openserial_vars.outputBufFilled = FALSE;
|
||
|
! openserial_vars.outputBufIdxR = 0;
|
||
|
! openserial_vars.outputBufIdxW = 0;
|
||
|
!
|
||
|
! // set callbacks
|
||
|
! uart_setCallbacks(isr_openserial_tx,
|
||
|
! isr_openserial_rx);
|
||
|
! }
|
||
|
!
|
||
|
! error_t openserial_printStatus(uint8_t statusElement,uint8_t* buffer, uint16_t length) {
|
||
|
! uint8_t i;
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
!
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.outputBufFilled = TRUE;
|
||
|
! outputHdlcOpen();
|
||
|
! outputHdlcWrite(SERFRAME_MOTE2PC_STATUS);
|
||
|
! outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[0]);
|
||
|
! outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[1]);
|
||
|
! outputHdlcWrite(statusElement);
|
||
|
! for (i=0;i<length;i++){
|
||
|
! outputHdlcWrite(buffer[i]);
|
||
|
! }
|
||
|
! outputHdlcClose();
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
|
||
|
return E_SUCCESS;
|
||
|
}
|
||
|
|
||
|
! error_t openserial_printInfoErrorCritical(
|
||
|
char severity,
|
||
|
uint8_t calling_component,
|
||
|
uint8_t error_code,
|
||
|
errorparameter_t arg1,
|
||
|
errorparameter_t arg2
|
||
|
) {
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
!
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.outputBufFilled = TRUE;
|
||
|
! outputHdlcOpen();
|
||
|
! outputHdlcWrite(severity);
|
||
|
! outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[0]);
|
||
|
! outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[1]);
|
||
|
! outputHdlcWrite(calling_component);
|
||
|
! outputHdlcWrite(error_code);
|
||
|
! outputHdlcWrite((uint8_t)((arg1 & 0xff00)>>8));
|
||
|
! outputHdlcWrite((uint8_t) (arg1 & 0x00ff));
|
||
|
! outputHdlcWrite((uint8_t)((arg2 & 0xff00)>>8));
|
||
|
! outputHdlcWrite((uint8_t) (arg2 & 0x00ff));
|
||
|
! outputHdlcClose();
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
|
||
|
return E_SUCCESS;
|
||
|
}
|
||
|
|
||
|
! error_t openserial_printData(uint8_t* buffer, uint8_t length) {
|
||
|
! uint8_t i;
|
||
|
! uint8_t asn[5];
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
!
|
||
|
! // retrieve ASN
|
||
|
! asnWriteToSerial(asn);// byte01,byte23,byte4
|
||
|
!
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.outputBufFilled = TRUE;
|
||
|
! outputHdlcOpen();
|
||
|
! outputHdlcWrite(SERFRAME_MOTE2PC_DATA);
|
||
|
! outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[1]);
|
||
|
! outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[0]);
|
||
|
! outputHdlcWrite(asn[0]);
|
||
|
! outputHdlcWrite(asn[1]);
|
||
|
! outputHdlcWrite(asn[2]);
|
||
|
! outputHdlcWrite(asn[3]);
|
||
|
! outputHdlcWrite(asn[4]);
|
||
|
! for (i=0;i<length;i++){
|
||
|
! outputHdlcWrite(buffer[i]);
|
||
|
! }
|
||
|
! outputHdlcClose();
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
|
||
|
return E_SUCCESS;
|
||
|
}
|
||
|
|
||
|
! error_t openserial_printInfo(uint8_t calling_component, uint8_t error_code,
|
||
|
errorparameter_t arg1,
|
||
|
errorparameter_t arg2) {
|
||
|
return openserial_printInfoErrorCritical(
|
||
|
--- 37,165 ----
|
||
|
errorparameter_t arg2
|
||
|
);
|
||
|
// HDLC output
|
||
|
! void outputHdlcOpen(void);
|
||
|
void outputHdlcWrite(uint8_t b);
|
||
|
! void outputHdlcClose(void);
|
||
|
// HDLC input
|
||
|
! void inputHdlcOpen(void);
|
||
|
void inputHdlcWrite(uint8_t b);
|
||
|
! void inputHdlcClose(void);
|
||
|
|
||
|
//=========================== public ==========================================
|
||
|
|
||
|
! void openserial_init(void) {
|
||
|
! // uint16_t crc;
|
||
|
! //
|
||
|
! // // reset variable
|
||
|
! // memset(&openserial_vars,0,sizeof(openserial_vars_t));
|
||
|
! //
|
||
|
! // // admin
|
||
|
! // openserial_vars.mode = MODE_OFF;
|
||
|
! // openserial_vars.debugPrintCounter = 0;
|
||
|
! //
|
||
|
! // // input
|
||
|
! // openserial_vars.reqFrame[0] = HDLC_FLAG;
|
||
|
! // openserial_vars.reqFrame[1] = SERFRAME_MOTE2PC_REQUEST;
|
||
|
! // crc = HDLC_CRCINIT;
|
||
|
! // crc = crcIteration(crc,openserial_vars.reqFrame[1]);
|
||
|
! // crc = ~crc;
|
||
|
! // openserial_vars.reqFrame[2] = (crc>>0)&0xff;
|
||
|
! // openserial_vars.reqFrame[3] = (crc>>8)&0xff;
|
||
|
! // openserial_vars.reqFrame[4] = HDLC_FLAG;
|
||
|
! // openserial_vars.reqFrameIdx = 0;
|
||
|
! // openserial_vars.lastRxByte = HDLC_FLAG;
|
||
|
! // openserial_vars.busyReceiving = FALSE;
|
||
|
! // openserial_vars.inputEscaping = FALSE;
|
||
|
! // openserial_vars.inputBufFill = 0;
|
||
|
! //
|
||
|
! // // ouput
|
||
|
! // openserial_vars.outputBufFilled = FALSE;
|
||
|
! // openserial_vars.outputBufIdxR = 0;
|
||
|
! // openserial_vars.outputBufIdxW = 0;
|
||
|
! //
|
||
|
! // // set callbacks
|
||
|
! // uart_setCallbacks(isr_openserial_tx,
|
||
|
! // isr_openserial_rx);
|
||
|
! }
|
||
|
!
|
||
|
! owerror_t openserial_printStatus(uint8_t statusElement,uint8_t* buffer, uint8_t length) {
|
||
|
! // uint8_t i;
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.outputBufFilled = TRUE;
|
||
|
! // outputHdlcOpen();
|
||
|
! // outputHdlcWrite(SERFRAME_MOTE2PC_STATUS);
|
||
|
! // outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[0]);
|
||
|
! // outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[1]);
|
||
|
! // outputHdlcWrite(statusElement);
|
||
|
! // for (i=0;i<length;i++){
|
||
|
! // outputHdlcWrite(buffer[i]);
|
||
|
! // }
|
||
|
! // outputHdlcClose();
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
|
||
|
return E_SUCCESS;
|
||
|
}
|
||
|
|
||
|
! owerror_t openserial_printInfoErrorCritical(
|
||
|
char severity,
|
||
|
uint8_t calling_component,
|
||
|
uint8_t error_code,
|
||
|
errorparameter_t arg1,
|
||
|
errorparameter_t arg2
|
||
|
) {
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.outputBufFilled = TRUE;
|
||
|
! // outputHdlcOpen();
|
||
|
! // outputHdlcWrite(severity);
|
||
|
! // outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[0]);
|
||
|
! // outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[1]);
|
||
|
! // outputHdlcWrite(calling_component);
|
||
|
! // outputHdlcWrite(error_code);
|
||
|
! // outputHdlcWrite((uint8_t)((arg1 & 0xff00)>>8));
|
||
|
! // outputHdlcWrite((uint8_t) (arg1 & 0x00ff));
|
||
|
! // outputHdlcWrite((uint8_t)((arg2 & 0xff00)>>8));
|
||
|
! // outputHdlcWrite((uint8_t) (arg2 & 0x00ff));
|
||
|
! // outputHdlcClose();
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
|
||
|
return E_SUCCESS;
|
||
|
}
|
||
|
|
||
|
! owerror_t openserial_printData(uint8_t* buffer, uint8_t length) {
|
||
|
! (void)length;
|
||
|
! puts((char*)buffer);
|
||
|
! // uint8_t i;
|
||
|
! // uint8_t asn[5];
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! //
|
||
|
! // // retrieve ASN
|
||
|
! // ieee154e_getAsn(asn);// byte01,byte23,byte4
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.outputBufFilled = TRUE;
|
||
|
! // outputHdlcOpen();
|
||
|
! // outputHdlcWrite(SERFRAME_MOTE2PC_DATA);
|
||
|
! // outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[1]);
|
||
|
! // outputHdlcWrite(idmanager_getMyID(ADDR_16B)->addr_16b[0]);
|
||
|
! // outputHdlcWrite(asn[0]);
|
||
|
! // outputHdlcWrite(asn[1]);
|
||
|
! // outputHdlcWrite(asn[2]);
|
||
|
! // outputHdlcWrite(asn[3]);
|
||
|
! // outputHdlcWrite(asn[4]);
|
||
|
! // for (i=0;i<length;i++){
|
||
|
! // outputHdlcWrite(buffer[i]);
|
||
|
! // }
|
||
|
! // outputHdlcClose();
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
|
||
|
return E_SUCCESS;
|
||
|
}
|
||
|
|
||
|
! owerror_t openserial_printInfo(uint8_t calling_component, uint8_t error_code,
|
||
|
errorparameter_t arg1,
|
||
|
errorparameter_t arg2) {
|
||
|
return openserial_printInfoErrorCritical(
|
||
|
***************
|
||
|
*** 188,194 ****
|
||
|
);
|
||
|
}
|
||
|
|
||
|
! error_t openserial_printError(uint8_t calling_component, uint8_t error_code,
|
||
|
errorparameter_t arg1,
|
||
|
errorparameter_t arg2) {
|
||
|
// blink error LED, this is serious
|
||
|
--- 171,177 ----
|
||
|
);
|
||
|
}
|
||
|
|
||
|
! owerror_t openserial_printError(uint8_t calling_component, uint8_t error_code,
|
||
|
errorparameter_t arg1,
|
||
|
errorparameter_t arg2) {
|
||
|
// blink error LED, this is serious
|
||
|
***************
|
||
|
*** 203,218 ****
|
||
|
);
|
||
|
}
|
||
|
|
||
|
! error_t openserial_printCritical(uint8_t calling_component, uint8_t error_code,
|
||
|
errorparameter_t arg1,
|
||
|
errorparameter_t arg2) {
|
||
|
// blink error LED, this is serious
|
||
|
! leds_error_blink();
|
||
|
!
|
||
|
! // schedule for the mote to reboot in 10s
|
||
|
! opentimers_start(10000,
|
||
|
! TIMER_ONESHOT,TIME_MS,
|
||
|
! board_reset);
|
||
|
|
||
|
return openserial_printInfoErrorCritical(
|
||
|
SERFRAME_MOTE2PC_CRITICAL,
|
||
|
--- 186,201 ----
|
||
|
);
|
||
|
}
|
||
|
|
||
|
! owerror_t openserial_printCritical(uint8_t calling_component, uint8_t error_code,
|
||
|
errorparameter_t arg1,
|
||
|
errorparameter_t arg2) {
|
||
|
// blink error LED, this is serious
|
||
|
! leds_error_blink();
|
||
|
! //
|
||
|
! // // schedule for the mote to reboot in 10s
|
||
|
! // opentimers_start(10000,
|
||
|
! // TIMER_ONESHOT,TIME_MS,
|
||
|
! // board_reset);
|
||
|
|
||
|
return openserial_printInfoErrorCritical(
|
||
|
SERFRAME_MOTE2PC_CRITICAL,
|
||
|
***************
|
||
|
*** 223,412 ****
|
||
|
);
|
||
|
}
|
||
|
|
||
|
! uint8_t openserial_getNumDataBytes() {
|
||
|
! uint8_t inputBufFill;
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
!
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! inputBufFill = openserial_vars.inputBufFill;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
|
||
|
return inputBufFill-1; // removing the command byte
|
||
|
}
|
||
|
|
||
|
uint8_t openserial_getInputBuffer(uint8_t* bufferToWrite, uint8_t maxNumBytes) {
|
||
|
! uint8_t numBytesWritten;
|
||
|
! uint8_t inputBufFill;
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
!
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! inputBufFill = openserial_vars.inputBufFill;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
!
|
||
|
! if (maxNumBytes<inputBufFill-1) {
|
||
|
! openserial_printError(COMPONENT_OPENSERIAL,ERR_GETDATA_ASKS_TOO_FEW_BYTES,
|
||
|
! (errorparameter_t)maxNumBytes,
|
||
|
! (errorparameter_t)inputBufFill-1);
|
||
|
! numBytesWritten = 0;
|
||
|
! } else {
|
||
|
! numBytesWritten = inputBufFill-1;
|
||
|
! memcpy(bufferToWrite,&(openserial_vars.inputBuf[1]),numBytesWritten);
|
||
|
! }
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.inputBufFill=0;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
!
|
||
|
return numBytesWritten;
|
||
|
}
|
||
|
|
||
|
void openserial_startInput() {
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
!
|
||
|
! if (openserial_vars.inputBufFill>0) {
|
||
|
! openserial_printError(COMPONENT_OPENSERIAL,ERR_INPUTBUFFER_LENGTH,
|
||
|
! (errorparameter_t)openserial_vars.inputBufFill,
|
||
|
! (errorparameter_t)0);
|
||
|
! openserial_vars.inputBufFill = 0;
|
||
|
! }
|
||
|
!
|
||
|
! uart_clearTxInterrupts();
|
||
|
! uart_clearRxInterrupts(); // clear possible pending interrupts
|
||
|
! uart_enableInterrupts(); // Enable USCI_A1 TX & RX interrupt
|
||
|
!
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.mode = MODE_INPUT;
|
||
|
! openserial_vars.reqFrameIdx = 0;
|
||
|
! uart_writeByte(openserial_vars.reqFrame[openserial_vars.reqFrameIdx]);
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
! }
|
||
|
!
|
||
|
! void openserial_startOutput() {
|
||
|
! //schedule a task to get new status in the output buffer
|
||
|
! uint8_t debugPrintCounter;
|
||
|
!
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.debugPrintCounter = (openserial_vars.debugPrintCounter+1)%STATUS_MAX;
|
||
|
! debugPrintCounter = openserial_vars.debugPrintCounter;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
!
|
||
|
! // print debug information
|
||
|
! switch (debugPrintCounter) {
|
||
|
! case STATUS_ISSYNC:
|
||
|
! if (debugPrint_isSync()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_ID:
|
||
|
! if (debugPrint_id()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_DAGRANK:
|
||
|
! if (debugPrint_myDAGrank()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_OUTBUFFERINDEXES:
|
||
|
! if (debugPrint_outBufferIndexes()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_ASN:
|
||
|
! if (debugPrint_asn()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_MACSTATS:
|
||
|
! if (debugPrint_macStats()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_SCHEDULE:
|
||
|
! if(debugPrint_schedule()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_BACKOFF:
|
||
|
! if(debugPrint_backoff()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_QUEUE:
|
||
|
! if(debugPrint_queue()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! case STATUS_NEIGHBORS:
|
||
|
! if (debugPrint_neighbors()==TRUE) {
|
||
|
! break;
|
||
|
! }
|
||
|
! default:
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.debugPrintCounter=0;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
! }
|
||
|
!
|
||
|
! // flush buffer
|
||
|
! uart_clearTxInterrupts();
|
||
|
! uart_clearRxInterrupts(); // clear possible pending interrupts
|
||
|
! uart_enableInterrupts(); // Enable USCI_A1 TX & RX interrupt
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.mode=MODE_OUTPUT;
|
||
|
! if (openserial_vars.outputBufFilled) {
|
||
|
! uart_writeByte(openserial_vars.outputBuf[openserial_vars.outputBufIdxR++]);
|
||
|
! } else {
|
||
|
! openserial_stop();
|
||
|
! }
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
! }
|
||
|
!
|
||
|
! void openserial_stop() {
|
||
|
! uint8_t inputBufFill;
|
||
|
! uint8_t cmdByte;
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
!
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! inputBufFill = openserial_vars.inputBufFill;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
!
|
||
|
! // disable USCI_A1 TX & RX interrupt
|
||
|
! uart_disableInterrupts();
|
||
|
!
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.mode=MODE_OFF;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
!
|
||
|
! if (inputBufFill>0) {
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! cmdByte = openserial_vars.inputBuf[0];
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
! switch (cmdByte) {
|
||
|
! case SERFRAME_PC2MOTE_SETROOT:
|
||
|
! idmanager_triggerAboutRoot();
|
||
|
! break;
|
||
|
! case SERFRAME_PC2MOTE_SETBRIDGE:
|
||
|
! idmanager_triggerAboutBridge();
|
||
|
! break;
|
||
|
! case SERFRAME_PC2MOTE_DATA:
|
||
|
! openbridge_triggerData();
|
||
|
! break;
|
||
|
! case SERFRAME_PC2MOTE_TRIGGERTCPINJECT:
|
||
|
! tcpinject_trigger();
|
||
|
! break;
|
||
|
! case SERFRAME_PC2MOTE_TRIGGERUDPINJECT:
|
||
|
! udpinject_trigger();
|
||
|
! break;
|
||
|
! case SERFRAME_PC2MOTE_TRIGGERICMPv6ECHO:
|
||
|
! icmpv6echo_trigger();
|
||
|
! break;
|
||
|
! case SERFRAME_PC2MOTE_TRIGGERSERIALECHO:
|
||
|
! openserial_echo(&openserial_vars.inputBuf[1],inputBufFill-1);
|
||
|
! break;
|
||
|
! default:
|
||
|
! openserial_printError(COMPONENT_OPENSERIAL,ERR_UNSUPPORTED_COMMAND,
|
||
|
! (errorparameter_t)cmdByte,
|
||
|
! (errorparameter_t)0);
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.inputBufFill = 0;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
! break;
|
||
|
! }
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! openserial_vars.inputBufFill = 0;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
! }
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
--- 206,424 ----
|
||
|
);
|
||
|
}
|
||
|
|
||
|
! uint8_t openserial_getNumDataBytes(void) {
|
||
|
! uint8_t inputBufFill=0;
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // inputBufFill = openserial_vars.inputBufFill;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
|
||
|
return inputBufFill-1; // removing the command byte
|
||
|
}
|
||
|
|
||
|
uint8_t openserial_getInputBuffer(uint8_t* bufferToWrite, uint8_t maxNumBytes) {
|
||
|
! uint8_t numBytesWritten=0;
|
||
|
! // uint8_t inputBufFill;
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // inputBufFill = openserial_vars.inputBufFill;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! //
|
||
|
! // if (maxNumBytes<inputBufFill-1) {
|
||
|
! // openserial_printError(COMPONENT_OPENSERIAL,ERR_GETDATA_ASKS_TOO_FEW_BYTES,
|
||
|
! // (errorparameter_t)maxNumBytes,
|
||
|
! // (errorparameter_t)inputBufFill-1);
|
||
|
! // numBytesWritten = 0;
|
||
|
! // } else {
|
||
|
! // numBytesWritten = inputBufFill-1;
|
||
|
! // memcpy(bufferToWrite,&(openserial_vars.inputBuf[1]),numBytesWritten);
|
||
|
! // }
|
||
|
!
|
||
|
return numBytesWritten;
|
||
|
}
|
||
|
|
||
|
void openserial_startInput() {
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! //
|
||
|
! // if (openserial_vars.inputBufFill>0) {
|
||
|
! // openserial_printError(COMPONENT_OPENSERIAL,ERR_INPUTBUFFER_LENGTH,
|
||
|
! // (errorparameter_t)openserial_vars.inputBufFill,
|
||
|
! // (errorparameter_t)0);
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.inputBufFill=0;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! // }
|
||
|
! //
|
||
|
! // uart_clearTxInterrupts();
|
||
|
! // uart_clearRxInterrupts(); // clear possible pending interrupts
|
||
|
! // uart_enableInterrupts(); // Enable USCI_A1 TX & RX interrupt
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.busyReceiving = FALSE;
|
||
|
! // openserial_vars.mode = MODE_INPUT;
|
||
|
! // openserial_vars.reqFrameIdx = 0;
|
||
|
! // #ifdef FASTSIM
|
||
|
! // uart_writeBufferByLen_FASTSIM(
|
||
|
! // openserial_vars.reqFrame,
|
||
|
! // sizeof(openserial_vars.reqFrame)
|
||
|
! // );
|
||
|
! // openserial_vars.reqFrameIdx = sizeof(openserial_vars.reqFrame);
|
||
|
! // #else
|
||
|
! // uart_writeByte(openserial_vars.reqFrame[openserial_vars.reqFrameIdx]);
|
||
|
! // #endif
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! }
|
||
|
!
|
||
|
! void openserial_startOutput(void) {
|
||
|
! // //schedule a task to get new status in the output buffer
|
||
|
! // uint8_t debugPrintCounter;
|
||
|
! //
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.debugPrintCounter = (openserial_vars.debugPrintCounter+1)%STATUS_MAX;
|
||
|
! // debugPrintCounter = openserial_vars.debugPrintCounter;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! //
|
||
|
! // // print debug information
|
||
|
! // switch (debugPrintCounter) {
|
||
|
! // case STATUS_ISSYNC:
|
||
|
! // if (debugPrint_isSync()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_ID:
|
||
|
! // if (debugPrint_id()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_DAGRANK:
|
||
|
! // if (debugPrint_myDAGrank()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_OUTBUFFERINDEXES:
|
||
|
! // if (debugPrint_outBufferIndexes()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_ASN:
|
||
|
! // if (debugPrint_asn()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_MACSTATS:
|
||
|
! // if (debugPrint_macStats()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_SCHEDULE:
|
||
|
! // if(debugPrint_schedule()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_BACKOFF:
|
||
|
! // if(debugPrint_backoff()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_QUEUE:
|
||
|
! // if(debugPrint_queue()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // case STATUS_NEIGHBORS:
|
||
|
! // if (debugPrint_neighbors()==TRUE) {
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // default:
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.debugPrintCounter=0;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! // }
|
||
|
! //
|
||
|
! // // flush buffer
|
||
|
! // uart_clearTxInterrupts();
|
||
|
! // uart_clearRxInterrupts(); // clear possible pending interrupts
|
||
|
! // uart_enableInterrupts(); // Enable USCI_A1 TX & RX interrupt
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.mode=MODE_OUTPUT;
|
||
|
! // if (openserial_vars.outputBufFilled) {
|
||
|
! // #ifdef FASTSIM
|
||
|
! // uart_writeCircularBuffer_FASTSIM(
|
||
|
! // openserial_vars.outputBuf,
|
||
|
! // &openserial_vars.outputBufIdxR,
|
||
|
! // &openserial_vars.outputBufIdxW
|
||
|
! // );
|
||
|
! // #else
|
||
|
! // uart_writeByte(openserial_vars.outputBuf[openserial_vars.outputBufIdxR++]);
|
||
|
! // #endif
|
||
|
! // } else {
|
||
|
! // openserial_stop();
|
||
|
! // }
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! }
|
||
|
!
|
||
|
! void openserial_stop(void) {
|
||
|
! // uint8_t inputBufFill;
|
||
|
! // uint8_t cmdByte;
|
||
|
! // bool busyReceiving;
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // busyReceiving = openserial_vars.busyReceiving;
|
||
|
! // inputBufFill = openserial_vars.inputBufFill;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! //
|
||
|
! // // disable USCI_A1 TX & RX interrupt
|
||
|
! // uart_disableInterrupts();
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.mode=MODE_OFF;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! // //the inputBuffer has to be reset if it is not reset where the data is read.
|
||
|
! // //or the function openserial_getInputBuffer is called (which resets the buffer)
|
||
|
! // if (busyReceiving==TRUE){
|
||
|
! // openserial_printError(COMPONENT_OPENSERIAL,ERR_BUSY_RECEIVING,
|
||
|
! // (errorparameter_t)0,
|
||
|
! // (errorparameter_t)inputBufFill);
|
||
|
! // }
|
||
|
! //
|
||
|
! // if (busyReceiving == FALSE && inputBufFill>0) {
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // cmdByte = openserial_vars.inputBuf[0];
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! // switch (cmdByte) {
|
||
|
! // case SERFRAME_PC2MOTE_SETROOT:
|
||
|
! // idmanager_triggerAboutRoot();
|
||
|
! // break;
|
||
|
! // case SERFRAME_PC2MOTE_SETBRIDGE:
|
||
|
! // idmanager_triggerAboutBridge();
|
||
|
! // break;
|
||
|
! // case SERFRAME_PC2MOTE_DATA:
|
||
|
! // openbridge_triggerData();
|
||
|
! // break;
|
||
|
! // case SERFRAME_PC2MOTE_TRIGGERTCPINJECT:
|
||
|
! // tcpinject_trigger();
|
||
|
! // break;
|
||
|
! // case SERFRAME_PC2MOTE_TRIGGERUDPINJECT:
|
||
|
! // udpinject_trigger();
|
||
|
! // break;
|
||
|
! // case SERFRAME_PC2MOTE_TRIGGERICMPv6ECHO:
|
||
|
! // icmpv6echo_trigger();
|
||
|
! // break;
|
||
|
! // case SERFRAME_PC2MOTE_TRIGGERSERIALECHO:
|
||
|
! // //echo function must reset input buffer after reading the data.
|
||
|
! // openserial_echo(&openserial_vars.inputBuf[1],inputBufFill-1);
|
||
|
! // break;
|
||
|
! // default:
|
||
|
! // openserial_printError(COMPONENT_OPENSERIAL,ERR_UNSUPPORTED_COMMAND,
|
||
|
! // (errorparameter_t)cmdByte,
|
||
|
! // (errorparameter_t)0);
|
||
|
! // //reset here as it is not being reset in any other callback
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.inputBufFill = 0;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // }
|
||
|
! //
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // openserial_vars.inputBufFill = 0;
|
||
|
! // openserial_vars.busyReceiving = FALSE;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
***************
|
||
|
*** 417,430 ****
|
||
|
|
||
|
\returns TRUE if this function printed something, FALSE otherwise.
|
||
|
*/
|
||
|
! bool debugPrint_outBufferIndexes() {
|
||
|
! uint16_t temp_buffer[2];
|
||
|
! INTERRUPT_DECLARATION();
|
||
|
! DISABLE_INTERRUPTS();
|
||
|
! temp_buffer[0] = openserial_vars.outputBufIdxW;
|
||
|
! temp_buffer[1] = openserial_vars.outputBufIdxR;
|
||
|
! ENABLE_INTERRUPTS();
|
||
|
! openserial_printStatus(STATUS_OUTBUFFERINDEXES,(uint8_t*)temp_buffer,sizeof(temp_buffer));
|
||
|
return TRUE;
|
||
|
}
|
||
|
|
||
|
--- 429,442 ----
|
||
|
|
||
|
\returns TRUE if this function printed something, FALSE otherwise.
|
||
|
*/
|
||
|
! bool debugPrint_outBufferIndexes(void) {
|
||
|
! // uint16_t temp_buffer[2];
|
||
|
! // INTERRUPT_DECLARATION();
|
||
|
! // DISABLE_INTERRUPTS();
|
||
|
! // temp_buffer[0] = openserial_vars.outputBufIdxW;
|
||
|
! // temp_buffer[1] = openserial_vars.outputBufIdxR;
|
||
|
! // ENABLE_INTERRUPTS();
|
||
|
! // openserial_printStatus(STATUS_OUTBUFFERINDEXES,(uint8_t*)temp_buffer,sizeof(temp_buffer));
|
||
|
return TRUE;
|
||
|
}
|
||
|
|
||
|
***************
|
||
|
*** 435,633 ****
|
||
|
/**
|
||
|
\brief Start an HDLC frame in the output buffer.
|
||
|
*/
|
||
|
! inline void outputHdlcOpen() {
|
||
|
! // initialize the value of the CRC
|
||
|
! openserial_vars.outputCrc = HDLC_CRCINIT;
|
||
|
!
|
||
|
! // write the opening HDLC flag
|
||
|
! openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_FLAG;
|
||
|
! }
|
||
|
/**
|
||
|
\brief Add a byte to the outgoing HDLC frame being built.
|
||
|
-
|
||
|
- \todo escape 0x7e and 0x7d.
|
||
|
*/
|
||
|
! inline void outputHdlcWrite(uint8_t b) {
|
||
|
!
|
||
|
! // iterate through CRC calculator
|
||
|
! openserial_vars.outputCrc = crcIteration(openserial_vars.outputCrc,b);
|
||
|
!
|
||
|
! // add byte to buffer
|
||
|
! if (b==HDLC_FLAG || b==HDLC_ESCAPE) {
|
||
|
! openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_ESCAPE;
|
||
|
! b = b^HDLC_ESCAPE_MASK;
|
||
|
! }
|
||
|
! openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = b;
|
||
|
!
|
||
|
! }
|
||
|
/**
|
||
|
\brief Finalize the outgoing HDLC frame.
|
||
|
*/
|
||
|
! inline void outputHdlcClose() {
|
||
|
! // finalize the calculation of the CRC
|
||
|
! openserial_vars.outputCrc = ~openserial_vars.outputCrc;
|
||
|
!
|
||
|
! // write the CRC value
|
||
|
! openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = (openserial_vars.outputCrc>>0)&0xff;
|
||
|
! openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = (openserial_vars.outputCrc>>8)&0xff;
|
||
|
!
|
||
|
! // write the closing HDLC flag
|
||
|
! openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_FLAG;
|
||
|
! }
|
||
|
|
||
|
//===== hdlc (input)
|
||
|
|
||
|
/**
|
||
|
\brief Start an HDLC frame in the input buffer.
|
||
|
*/
|
||
|
! inline void inputHdlcOpen() {
|
||
|
! // reset the input buffer index
|
||
|
! openserial_vars.inputBufFill = 0;
|
||
|
!
|
||
|
! // initialize the value of the CRC
|
||
|
! openserial_vars.inputCrc = HDLC_CRCINIT;
|
||
|
! }
|
||
|
/**
|
||
|
\brief Add a byte to the incoming HDLC frame.
|
||
|
-
|
||
|
- \todo escape 0x7e and 0x7d.
|
||
|
*/
|
||
|
! inline void inputHdlcWrite(uint8_t b) {
|
||
|
! if (b==HDLC_ESCAPE) {
|
||
|
! openserial_vars.inputEscaping = TRUE;
|
||
|
! } else {
|
||
|
! if (openserial_vars.inputEscaping==TRUE) {
|
||
|
! b = b^HDLC_ESCAPE_MASK;
|
||
|
! openserial_vars.inputEscaping = FALSE;
|
||
|
! }
|
||
|
!
|
||
|
! // add byte to input buffer
|
||
|
! openserial_vars.inputBuf[openserial_vars.inputBufFill] = b;
|
||
|
! openserial_vars.inputBufFill++;
|
||
|
!
|
||
|
! // iterate through CRC calculator
|
||
|
! openserial_vars.inputCrc = crcIteration(openserial_vars.inputCrc,b);
|
||
|
! }
|
||
|
! }
|
||
|
/**
|
||
|
\brief Finalize the incoming HDLC frame.
|
||
|
*/
|
||
|
! inline void inputHdlcClose() {
|
||
|
!
|
||
|
! // verify the validity of the frame
|
||
|
! if (openserial_vars.inputCrc==HDLC_CRCGOOD) {
|
||
|
! // the CRC is correct
|
||
|
!
|
||
|
! // remove the CRC from the input buffer
|
||
|
! openserial_vars.inputBufFill -= 2;
|
||
|
! } else {
|
||
|
! // the CRC is incorrect
|
||
|
!
|
||
|
! // drop the incoming fram
|
||
|
! openserial_vars.inputBufFill = 0;
|
||
|
! }
|
||
|
! }
|
||
|
|
||
|
//=========================== interrupt handlers ==============================
|
||
|
|
||
|
- //executed in ISR, called from scheduler.c
|
||
|
- void isr_openserial_tx() {
|
||
|
- switch (openserial_vars.mode) {
|
||
|
- case MODE_INPUT:
|
||
|
- openserial_vars.reqFrameIdx++;
|
||
|
- if (openserial_vars.reqFrameIdx<sizeof(openserial_vars.reqFrame)) {
|
||
|
- uart_writeByte(openserial_vars.reqFrame[openserial_vars.reqFrameIdx]);
|
||
|
- }
|
||
|
- break;
|
||
|
- case MODE_OUTPUT:
|
||
|
- if (openserial_vars.outputBufIdxW==openserial_vars.outputBufIdxR) {
|
||
|
- openserial_vars.outputBufFilled = FALSE;
|
||
|
- }
|
||
|
- if (openserial_vars.outputBufFilled) {
|
||
|
- uart_writeByte(openserial_vars.outputBuf[openserial_vars.outputBufIdxR++]);
|
||
|
- }
|
||
|
- break;
|
||
|
- case MODE_OFF:
|
||
|
- default:
|
||
|
- break;
|
||
|
- }
|
||
|
- }
|
||
|
-
|
||
|
// executed in ISR, called from scheduler.c
|
||
|
! void isr_openserial_rx() {
|
||
|
! uint8_t rxbyte;
|
||
|
!
|
||
|
! // stop if I'm not in input mode
|
||
|
! if (openserial_vars.mode!=MODE_INPUT) {
|
||
|
! return;
|
||
|
! }
|
||
|
!
|
||
|
! // read byte just received
|
||
|
! rxbyte = uart_readByte();
|
||
|
!
|
||
|
! if (
|
||
|
! openserial_vars.busyReceiving==FALSE &&
|
||
|
! openserial_vars.lastRxByte==HDLC_FLAG &&
|
||
|
! rxbyte!=HDLC_FLAG
|
||
|
! ) {
|
||
|
! // start of frame
|
||
|
!
|
||
|
! // I'm now receiving
|
||
|
! openserial_vars.busyReceiving = TRUE;
|
||
|
!
|
||
|
! // create the HDLC frame
|
||
|
! inputHdlcOpen();
|
||
|
!
|
||
|
! // add the byte just received
|
||
|
! inputHdlcWrite(rxbyte);
|
||
|
! } else if (
|
||
|
! openserial_vars.busyReceiving==TRUE &&
|
||
|
! rxbyte!=HDLC_FLAG
|
||
|
! ) {
|
||
|
! // middle of frame
|
||
|
!
|
||
|
! // add the byte just received
|
||
|
! inputHdlcWrite(rxbyte);
|
||
|
! if (openserial_vars.inputBufFill+1>SERIAL_INPUT_BUFFER_SIZE){
|
||
|
! // input buffer overflow
|
||
|
! openserial_printError(COMPONENT_OPENSERIAL,ERR_INPUT_BUFFER_OVERFLOW,
|
||
|
! (errorparameter_t)0,
|
||
|
! (errorparameter_t)0);
|
||
|
! openserial_vars.inputBufFill = 0;
|
||
|
! openserial_vars.busyReceiving = FALSE;
|
||
|
! openserial_stop();
|
||
|
! }
|
||
|
! } else if (
|
||
|
! openserial_vars.busyReceiving==TRUE &&
|
||
|
! rxbyte==HDLC_FLAG
|
||
|
! ) {
|
||
|
! // end of frame
|
||
|
!
|
||
|
! // finalize the HDLC frame
|
||
|
! inputHdlcClose();
|
||
|
!
|
||
|
! if (openserial_vars.inputBufFill==0){
|
||
|
! // invalid HDLC frame
|
||
|
! openserial_printError(COMPONENT_OPENSERIAL,ERR_INVALIDSERIALFRAME,
|
||
|
! (errorparameter_t)0,
|
||
|
! (errorparameter_t)0);
|
||
|
!
|
||
|
! }
|
||
|
!
|
||
|
! openserial_vars.busyReceiving = FALSE;
|
||
|
! openserial_stop();
|
||
|
! }
|
||
|
!
|
||
|
! openserial_vars.lastRxByte = rxbyte;
|
||
|
! }
|
||
|
|
||
|
|
||
|
//======== SERIAL ECHO =============
|
||
|
|
||
|
void openserial_echo(uint8_t* buf, uint8_t bufLen){
|
||
|
// echo back what you received
|
||
|
openserial_printData(
|
||
|
buf,
|
||
|
bufLen
|
||
|
);
|
||
|
}
|
||
|
--- 447,650 ----
|
||
|
/**
|
||
|
\brief Start an HDLC frame in the output buffer.
|
||
|
*/
|
||
|
! // inline void outputHdlcOpen(void) {
|
||
|
! // // initialize the value of the CRC
|
||
|
! // openserial_vars.outputCrc = HDLC_CRCINIT;
|
||
|
! //
|
||
|
! // // write the opening HDLC flag
|
||
|
! // openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_FLAG;
|
||
|
! // }
|
||
|
/**
|
||
|
\brief Add a byte to the outgoing HDLC frame being built.
|
||
|
*/
|
||
|
! // inline void outputHdlcWrite(uint8_t b) {
|
||
|
! //
|
||
|
! // // iterate through CRC calculator
|
||
|
! // openserial_vars.outputCrc = crcIteration(openserial_vars.outputCrc,b);
|
||
|
! //
|
||
|
! // // add byte to buffer
|
||
|
! // if (b==HDLC_FLAG || b==HDLC_ESCAPE) {
|
||
|
! // openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_ESCAPE;
|
||
|
! // b = b^HDLC_ESCAPE_MASK;
|
||
|
! // }
|
||
|
! // openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = b;
|
||
|
! //
|
||
|
! // }
|
||
|
/**
|
||
|
\brief Finalize the outgoing HDLC frame.
|
||
|
*/
|
||
|
! // inline void outputHdlcClose(void) {
|
||
|
! // uint16_t finalCrc;
|
||
|
! //
|
||
|
! // // finalize the calculation of the CRC
|
||
|
! // finalCrc = ~openserial_vars.outputCrc;
|
||
|
! //
|
||
|
! // // write the CRC value
|
||
|
! // outputHdlcWrite((finalCrc>>0)&0xff);
|
||
|
! // outputHdlcWrite((finalCrc>>8)&0xff);
|
||
|
! //
|
||
|
! // // write the closing HDLC flag
|
||
|
! // openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_FLAG;
|
||
|
! // }
|
||
|
|
||
|
//===== hdlc (input)
|
||
|
|
||
|
/**
|
||
|
\brief Start an HDLC frame in the input buffer.
|
||
|
*/
|
||
|
! // inline void inputHdlcOpen(void) {
|
||
|
! // // reset the input buffer index
|
||
|
! // openserial_vars.inputBufFill = 0;
|
||
|
! //
|
||
|
! // // initialize the value of the CRC
|
||
|
! // openserial_vars.inputCrc = HDLC_CRCINIT;
|
||
|
! // }
|
||
|
/**
|
||
|
\brief Add a byte to the incoming HDLC frame.
|
||
|
*/
|
||
|
! // inline void inputHdlcWrite(uint8_t b) {
|
||
|
! // if (b==HDLC_ESCAPE) {
|
||
|
! // openserial_vars.inputEscaping = TRUE;
|
||
|
! // } else {
|
||
|
! // if (openserial_vars.inputEscaping==TRUE) {
|
||
|
! // b = b^HDLC_ESCAPE_MASK;
|
||
|
! // openserial_vars.inputEscaping = FALSE;
|
||
|
! // }
|
||
|
! //
|
||
|
! // // add byte to input buffer
|
||
|
! // openserial_vars.inputBuf[openserial_vars.inputBufFill] = b;
|
||
|
! // openserial_vars.inputBufFill++;
|
||
|
! //
|
||
|
! // // iterate through CRC calculator
|
||
|
! // openserial_vars.inputCrc = crcIteration(openserial_vars.inputCrc,b);
|
||
|
! // }
|
||
|
! // }
|
||
|
/**
|
||
|
\brief Finalize the incoming HDLC frame.
|
||
|
*/
|
||
|
! // inline void inputHdlcClose(void) {
|
||
|
! //
|
||
|
! // // verify the validity of the frame
|
||
|
! // if (openserial_vars.inputCrc==HDLC_CRCGOOD) {
|
||
|
! // // the CRC is correct
|
||
|
! //
|
||
|
! // // remove the CRC from the input buffer
|
||
|
! // openserial_vars.inputBufFill -= 2;
|
||
|
! // } else {
|
||
|
! // // the CRC is incorrect
|
||
|
! //
|
||
|
! // // drop the incoming fram
|
||
|
! // openserial_vars.inputBufFill = 0;
|
||
|
! // }
|
||
|
! // }
|
||
|
|
||
|
//=========================== interrupt handlers ==============================
|
||
|
|
||
|
// executed in ISR, called from scheduler.c
|
||
|
! // void isr_openserial_tx(void) {
|
||
|
! // switch (openserial_vars.mode) {
|
||
|
! // case MODE_INPUT:
|
||
|
! // openserial_vars.reqFrameIdx++;
|
||
|
! // if (openserial_vars.reqFrameIdx<sizeof(openserial_vars.reqFrame)) {
|
||
|
! // uart_writeByte(openserial_vars.reqFrame[openserial_vars.reqFrameIdx]);
|
||
|
! // }
|
||
|
! // break;
|
||
|
! // case MODE_OUTPUT:
|
||
|
! // if (openserial_vars.outputBufIdxW==openserial_vars.outputBufIdxR) {
|
||
|
! // openserial_vars.outputBufFilled = FALSE;
|
||
|
! // }
|
||
|
! // if (openserial_vars.outputBufFilled) {
|
||
|
! // uart_writeByte(openserial_vars.outputBuf[openserial_vars.outputBufIdxR++]);
|
||
|
! // }
|
||
|
! // break;
|
||
|
! // case MODE_OFF:
|
||
|
! // default:
|
||
|
! // break;
|
||
|
! // }
|
||
|
! // }
|
||
|
|
||
|
+ // executed in ISR, called from scheduler.c
|
||
|
+ // void isr_openserial_rx(void) {
|
||
|
+ // uint8_t rxbyte;
|
||
|
+ // uint8_t inputBufFill;
|
||
|
+ //
|
||
|
+ // // stop if I'm not in input mode
|
||
|
+ // if (openserial_vars.mode!=MODE_INPUT) {
|
||
|
+ // return;
|
||
|
+ // }
|
||
|
+ //
|
||
|
+ // // read byte just received
|
||
|
+ // rxbyte = uart_readByte();
|
||
|
+ // //keep lenght
|
||
|
+ // inputBufFill=openserial_vars.inputBufFill;
|
||
|
+ //
|
||
|
+ // if (
|
||
|
+ // openserial_vars.busyReceiving==FALSE &&
|
||
|
+ // openserial_vars.lastRxByte==HDLC_FLAG &&
|
||
|
+ // rxbyte!=HDLC_FLAG
|
||
|
+ // ) {
|
||
|
+ // // start of frame
|
||
|
+ //
|
||
|
+ // // I'm now receiving
|
||
|
+ // openserial_vars.busyReceiving = TRUE;
|
||
|
+ //
|
||
|
+ // // create the HDLC frame
|
||
|
+ // inputHdlcOpen();
|
||
|
+ //
|
||
|
+ // // add the byte just received
|
||
|
+ // inputHdlcWrite(rxbyte);
|
||
|
+ // } else if (
|
||
|
+ // openserial_vars.busyReceiving==TRUE &&
|
||
|
+ // rxbyte!=HDLC_FLAG
|
||
|
+ // ) {
|
||
|
+ // // middle of frame
|
||
|
+ //
|
||
|
+ // // add the byte just received
|
||
|
+ // inputHdlcWrite(rxbyte);
|
||
|
+ // if (openserial_vars.inputBufFill+1>SERIAL_INPUT_BUFFER_SIZE){
|
||
|
+ // // input buffer overflow
|
||
|
+ // openserial_printError(COMPONENT_OPENSERIAL,ERR_INPUT_BUFFER_OVERFLOW,
|
||
|
+ // (errorparameter_t)0,
|
||
|
+ // (errorparameter_t)0);
|
||
|
+ // openserial_vars.inputBufFill = 0;
|
||
|
+ // openserial_vars.busyReceiving = FALSE;
|
||
|
+ // openserial_stop();
|
||
|
+ // }
|
||
|
+ // } else if (
|
||
|
+ // openserial_vars.busyReceiving==TRUE &&
|
||
|
+ // rxbyte==HDLC_FLAG
|
||
|
+ // ) {
|
||
|
+ // // end of frame
|
||
|
+ //
|
||
|
+ // // finalize the HDLC frame
|
||
|
+ // inputHdlcClose();
|
||
|
+ //
|
||
|
+ // if (openserial_vars.inputBufFill==0){
|
||
|
+ // // invalid HDLC frame
|
||
|
+ // openserial_printError(COMPONENT_OPENSERIAL,ERR_WRONG_CRC_INPUT,
|
||
|
+ // (errorparameter_t)inputBufFill,
|
||
|
+ // (errorparameter_t)0);
|
||
|
+ //
|
||
|
+ // }
|
||
|
+ //
|
||
|
+ // openserial_vars.busyReceiving = FALSE;
|
||
|
+ // openserial_stop();
|
||
|
+ // }
|
||
|
+ //
|
||
|
+ // openserial_vars.lastRxByte = rxbyte;
|
||
|
+ // }
|
||
|
|
||
|
//======== SERIAL ECHO =============
|
||
|
|
||
|
void openserial_echo(uint8_t* buf, uint8_t bufLen){
|
||
|
+ INTERRUPT_DECLARATION();
|
||
|
// echo back what you received
|
||
|
openserial_printData(
|
||
|
buf,
|
||
|
bufLen
|
||
|
);
|
||
|
+
|
||
|
+ DISABLE_INTERRUPTS();
|
||
|
+ openserial_vars.inputBufFill = 0;
|
||
|
+ ENABLE_INTERRUPTS();
|
||
|
}
|