/** EUSART Generated Driver File @Company Microchip Technology Inc. @File Name eusart.c @Summary This is the generated driver implementation file for the EUSART driver using PIC10 / PIC12 / PIC16 / PIC18 MCUs @Description This source file provides APIs for EUSART. Generation Information : Product Revision : PIC10 / PIC12 / PIC16 / PIC18 MCUs - 1.81.6 Device : PIC16F1829 Driver Version : 2.1.0 The generated drivers are tested against the following: Compiler : XC8 2.30 and above MPLAB : MPLAB X 5.40 */ /* (c) 2018 Microchip Technology Inc. and its subsidiaries. Subject to your compliance with these terms, you may use Microchip software and any derivatives exclusively with Microchip products. It is your responsibility to comply with third party license terms applicable to your use of third party software (including open source software) that may accompany Microchip software. THIS SOFTWARE IS SUPPLIED BY MICROCHIP "AS IS". NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, APPLY TO THIS SOFTWARE, INCLUDING ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE SOFTWARE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY RELATED TO THIS SOFTWARE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THIS SOFTWARE. */ /** Section: Included Files */ #include "eusart.h" /** Section: Macro Declarations */ #define EUSART_TX_BUFFER_SIZE 16 #define EUSART_RX_BUFFER_SIZE 16 /** Section: Global Variables */ volatile uint8_t eusartTxHead = 0; volatile uint8_t eusartTxTail = 0; volatile uint8_t eusartTxBuffer[EUSART_TX_BUFFER_SIZE]; volatile uint8_t eusartTxBufferRemaining; volatile uint8_t eusartRxHead = 0; volatile uint8_t eusartRxTail = 0; volatile uint8_t eusartRxBuffer[EUSART_RX_BUFFER_SIZE]; volatile eusart_status_t eusartRxStatusBuffer[EUSART_RX_BUFFER_SIZE]; volatile uint8_t eusartRxCount; volatile eusart_status_t eusartRxLastError; /** Section: EUSART APIs */ void (*EUSART_TxDefaultInterruptHandler)(void); void (*EUSART_RxDefaultInterruptHandler)(void); void (*EUSART_FramingErrorHandler)(void); void (*EUSART_OverrunErrorHandler)(void); void (*EUSART_ErrorHandler)(void); void EUSART_DefaultFramingErrorHandler(void); void EUSART_DefaultOverrunErrorHandler(void); void EUSART_DefaultErrorHandler(void); void EUSART_Initialize(void) { // disable interrupts before changing states PIE1bits.RCIE = 0; EUSART_SetRxInterruptHandler(EUSART_Receive_ISR); PIE1bits.TXIE = 0; EUSART_SetTxInterruptHandler(EUSART_Transmit_ISR); // Set the EUSART module to the options selected in the user interface. // ABDOVF no_overflow; SCKP Non-Inverted; BRG16 16bit_generator; WUE disabled; ABDEN disabled; BAUDCON = 0x08; // SPEN enabled; RX9 8-bit; CREN enabled; ADDEN disabled; SREN disabled; RCSTA = 0x90; // TX9 8-bit; TX9D 0; SENDB sync_break_complete; TXEN enabled; SYNC asynchronous; BRGH hi_speed; CSRC slave; TXSTA = 0x24; // SPBRGL 8; SPBRGL = 0x08; // SPBRGH 0; SPBRGH = 0x00; EUSART_SetFramingErrorHandler(EUSART_DefaultFramingErrorHandler); EUSART_SetOverrunErrorHandler(EUSART_DefaultOverrunErrorHandler); EUSART_SetErrorHandler(EUSART_DefaultErrorHandler); eusartRxLastError.status = 0; // initializing the driver state eusartTxHead = 0; eusartTxTail = 0; eusartTxBufferRemaining = sizeof(eusartTxBuffer); eusartRxHead = 0; eusartRxTail = 0; eusartRxCount = 0; // enable receive interrupt PIE1bits.RCIE = 1; } bool EUSART_is_tx_ready(void) { return (eusartTxBufferRemaining ? true : false); } bool EUSART_is_rx_ready(void) { return (eusartRxCount ? true : false); } bool EUSART_is_tx_done(void) { return TXSTAbits.TRMT; } eusart_status_t EUSART_get_last_status(void){ return eusartRxLastError; } uint8_t EUSART_Read(void) { uint8_t readValue = 0; while(0 == eusartRxCount) { } eusartRxLastError = eusartRxStatusBuffer[eusartRxTail]; readValue = eusartRxBuffer[eusartRxTail++]; if(sizeof(eusartRxBuffer) <= eusartRxTail) { eusartRxTail = 0; } PIE1bits.RCIE = 0; eusartRxCount--; PIE1bits.RCIE = 1; return readValue; } void EUSART_Write(uint8_t txData) { while(0 == eusartTxBufferRemaining) { } if(0 == PIE1bits.TXIE) { TXREG = txData; } else { PIE1bits.TXIE = 0; eusartTxBuffer[eusartTxHead++] = txData; if(sizeof(eusartTxBuffer) <= eusartTxHead) { eusartTxHead = 0; } eusartTxBufferRemaining--; } PIE1bits.TXIE = 1; } char getch(void) { return EUSART_Read(); } void putch(char txData) { EUSART_Write(txData); } void EUSART_Transmit_ISR(void) { // add your EUSART interrupt custom code if(sizeof(eusartTxBuffer) > eusartTxBufferRemaining) { TXREG = eusartTxBuffer[eusartTxTail++]; if(sizeof(eusartTxBuffer) <= eusartTxTail) { eusartTxTail = 0; } eusartTxBufferRemaining++; } else { PIE1bits.TXIE = 0; } } void EUSART_Receive_ISR(void) { eusartRxStatusBuffer[eusartRxHead].status = 0; if(RCSTAbits.FERR){ eusartRxStatusBuffer[eusartRxHead].ferr = 1; EUSART_FramingErrorHandler(); } if(RCSTAbits.OERR){ eusartRxStatusBuffer[eusartRxHead].oerr = 1; EUSART_OverrunErrorHandler(); } if(eusartRxStatusBuffer[eusartRxHead].status){ EUSART_ErrorHandler(); } else { EUSART_RxDataHandler(); } // or set custom function using EUSART_SetRxInterruptHandler() } void EUSART_RxDataHandler(void){ // use this default receive interrupt handler code eusartRxBuffer[eusartRxHead++] = RCREG; if(sizeof(eusartRxBuffer) <= eusartRxHead) { eusartRxHead = 0; } eusartRxCount++; } void EUSART_DefaultFramingErrorHandler(void){} void EUSART_DefaultOverrunErrorHandler(void){ // EUSART error - restart RCSTAbits.CREN = 0; RCSTAbits.CREN = 1; } void EUSART_DefaultErrorHandler(void){ EUSART_RxDataHandler(); } void EUSART_SetFramingErrorHandler(void (* interruptHandler)(void)){ EUSART_FramingErrorHandler = interruptHandler; } void EUSART_SetOverrunErrorHandler(void (* interruptHandler)(void)){ EUSART_OverrunErrorHandler = interruptHandler; } void EUSART_SetErrorHandler(void (* interruptHandler)(void)){ EUSART_ErrorHandler = interruptHandler; } void EUSART_SetTxInterruptHandler(void (* interruptHandler)(void)){ EUSART_TxDefaultInterruptHandler = interruptHandler; } void EUSART_SetRxInterruptHandler(void (* interruptHandler)(void)){ EUSART_RxDefaultInterruptHandler = interruptHandler; } /** End of File */