Advertisement
Mukmin039

EUSART1.c

Apr 8th, 2022
365
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 4.56 KB | None | 0 0
  1. /**
  2.   EUSART1 Generated Driver File
  3.  
  4.   @Company
  5.     Microchip Technology Inc.
  6.  
  7.   @File Name
  8.     eusart1.c
  9.  
  10.   @Summary
  11.     This is the generated driver implementation file for the EUSART1 driver using PIC10 / PIC12 / PIC16 / PIC18 MCUs
  12.  
  13.   @Description
  14.     This source file provides APIs for EUSART1.
  15.     Generation Information :
  16.         Product Revision  :  PIC10 / PIC12 / PIC16 / PIC18 MCUs - 1.81.7
  17.         Device            :  PIC18F46K22
  18.         Driver Version    :  2.1.1
  19.     The generated drivers are tested against the following:
  20.         Compiler          :  XC8 2.31 and above
  21.         MPLAB             :  MPLAB X 5.45
  22. */
  23.  
  24. /*
  25.     (c) 2018 Microchip Technology Inc. and its subsidiaries.
  26.    
  27.     Subject to your compliance with these terms, you may use Microchip software and any
  28.     derivatives exclusively with Microchip products. It is your responsibility to comply with third party
  29.     license terms applicable to your use of third party software (including open source software) that
  30.     may accompany Microchip software.
  31.    
  32.     THIS SOFTWARE IS SUPPLIED BY MICROCHIP "AS IS". NO WARRANTIES, WHETHER
  33.     EXPRESS, IMPLIED OR STATUTORY, APPLY TO THIS SOFTWARE, INCLUDING ANY
  34.     IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS
  35.     FOR A PARTICULAR PURPOSE.
  36.    
  37.     IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE,
  38.     INCIDENTAL OR CONSEQUENTIAL LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND
  39.     WHATSOEVER RELATED TO THE SOFTWARE, HOWEVER CAUSED, EVEN IF MICROCHIP
  40.     HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO
  41.     THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL
  42.     CLAIMS IN ANY WAY RELATED TO THIS SOFTWARE WILL NOT EXCEED THE AMOUNT
  43.     OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THIS
  44.     SOFTWARE.
  45. */
  46.  
  47. /**
  48.   Section: Included Files
  49. */
  50. #include "eusart1.h"
  51.  
  52. volatile eusart1_status_t eusart1RxLastError;
  53.  
  54. /**
  55.   Section: EUSART1 APIs
  56. */
  57.  
  58. void (*EUSART1_FramingErrorHandler)(void);
  59. void (*EUSART1_OverrunErrorHandler)(void);
  60. void (*EUSART1_ErrorHandler)(void);
  61.  
  62. void EUSART1_DefaultFramingErrorHandler(void);
  63. void EUSART1_DefaultOverrunErrorHandler(void);
  64. void EUSART1_DefaultErrorHandler(void);
  65.  
  66. void EUSART1_Initialize(void)
  67. {
  68.     // Set the EUSART1 module to the options selected in the user interface.
  69.  
  70.     // ABDOVF no_overflow; CKTXP async_noninverted_sync_fallingedge; BRG16 16bit_generator; WUE disabled; ABDEN disabled; DTRXP not_inverted;
  71.     BAUDCON1 = 0x08;
  72.  
  73.     // SPEN enabled; RX9 8-bit; CREN disabled; ADDEN disabled; SREN disabled;
  74.     RCSTA1 = 0x80;
  75.  
  76.     // TX9 8-bit; TX9D 0; SENDB sync_break_complete; TXEN enabled; SYNC asynchronous; BRGH hi_speed; CSRC slave_mode;
  77.     TXSTA1 = 0x24;
  78.  
  79.     //
  80.     SPBRG1 = 0x08;
  81.  
  82.     //
  83.     SPBRGH1 = 0x02;
  84.  
  85.  
  86.     EUSART1_SetFramingErrorHandler(EUSART1_DefaultFramingErrorHandler);
  87.     EUSART1_SetOverrunErrorHandler(EUSART1_DefaultOverrunErrorHandler);
  88.     EUSART1_SetErrorHandler(EUSART1_DefaultErrorHandler);
  89.  
  90.     eusart1RxLastError.status = 0;
  91.  
  92. }
  93.  
  94. bool EUSART1_is_tx_ready(void)
  95. {
  96.     return (bool)(PIR1bits.TX1IF && TXSTA1bits.TXEN);
  97. }
  98.  
  99. bool EUSART1_is_rx_ready(void)
  100. {
  101.     return (bool)(PIR1bits.RC1IF);
  102. }
  103.  
  104. bool EUSART1_is_tx_done(void)
  105. {
  106.     return TXSTA1bits.TRMT;
  107. }
  108.  
  109. eusart1_status_t EUSART1_get_last_status(void){
  110.     return eusart1RxLastError;
  111. }
  112.  
  113. uint8_t EUSART1_Read(void)
  114. {
  115.     while(!PIR1bits.RC1IF)
  116.     {
  117.     }
  118.  
  119.     eusart1RxLastError.status = 0;
  120.    
  121.     if(1 == RCSTA1bits.OERR)
  122.     {
  123.         // EUSART1 error - restart
  124.  
  125.         RCSTA1bits.CREN = 0;
  126.         RCSTA1bits.CREN = 1;
  127.     }
  128.  
  129.     return RCREG1;
  130. }
  131.  
  132. void EUSART1_Write(uint8_t txData)
  133. {
  134.     while(0 == PIR1bits.TX1IF)
  135.     {
  136.     }
  137.  
  138.     TXREG1 = txData;    // Write the data byte to the USART.
  139. }
  140.  
  141. char getch(void)
  142. {
  143.     return EUSART1_Read();
  144. }
  145.  
  146. void putch(char txData)
  147. {
  148.     EUSART1_Write(txData);
  149. }
  150.  
  151.  
  152.  
  153. void EUSART1_DefaultFramingErrorHandler(void){}
  154.  
  155. void EUSART1_DefaultOverrunErrorHandler(void){
  156.     // EUSART1 error - restart
  157.  
  158.     RCSTA1bits.CREN = 0;
  159.     RCSTA1bits.CREN = 1;
  160.  
  161. }
  162.  
  163. void EUSART1_DefaultErrorHandler(void){
  164. }
  165.  
  166. void EUSART1_SetFramingErrorHandler(void (* interruptHandler)(void)){
  167.     EUSART1_FramingErrorHandler = interruptHandler;
  168. }
  169.  
  170. void EUSART1_SetOverrunErrorHandler(void (* interruptHandler)(void)){
  171.     EUSART1_OverrunErrorHandler = interruptHandler;
  172. }
  173.  
  174. void EUSART1_SetErrorHandler(void (* interruptHandler)(void)){
  175.     EUSART1_ErrorHandler = interruptHandler;
  176. }
  177.  
  178.  
  179. /**
  180.   End of File
  181. */
  182.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement