From 33422427da1388cdd17fc81670b3cf340cb669c9 Mon Sep 17 00:00:00 2001 From: Roaming Date: Fri, 24 Jun 2016 07:40:18 +0530 Subject: [PATCH] Created a UART API definition in softuart.h to allow the example code to access UART in a standard manner , irrespective of how it is implemented. --- include/uart/api.h | 94 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 94 insertions(+) create mode 100644 include/uart/api.h diff --git a/include/uart/api.h b/include/uart/api.h new file mode 100644 index 0000000..82295a2 --- /dev/null +++ b/include/uart/api.h @@ -0,0 +1,94 @@ +/** \file include/uart/api.h + * This file is for defining a common API for accessing UARTs. + **/ + +#ifndef UART_API_H +#define UART_API_H + +#include "fx2types.h" +#include "stdarg.h" + +/** + * \brief Initalizes UART. + * Returns TRUE if initialization is successful. + * \param Rate See uartX_set_baud() + **/ +BOOL uartX_init(enum uart_baud rate, ...); + +/** + * enum Standard available baud rates. + * All enum values less than 0 are not supported. + * Enum values greater than 0 are supported. +**/ +enum uart_baud { + BAUD_FASTEST = -2, + BAUD_ANY = -1, + BAUD_INVALID = 0, + BAUD_2400 = 1, + BAUD_4800 = 2, + BAUD_9600 = 3, + BAUD_19200 = 4, + BAUD_38400 = 5, + BAUD_57600 = 6, + BAUD_115200 = 7 +}; + +/** + * \brief Sets the UART baud rate to one of the allowed parameters. + * Possible Baud rates: + * \li 2400 + * \li 4800 + * \li 9600 + * \li 19200 + * \li 28800 + * \li 38400 + * \li 57600 + * \li 115200 + * Returns TRUE if successful. +**/ +BOOL uartX_set_baud(enum uart_baud rate); + +/** + * \brief Returns the baud rate currently being used. +**/ +enum uart_baud uartX_get_baud(); + +/** + * \brief Transmits data through UART. + * \param c The character to be sent out. +**/ + +void uartX_tx(char c); + +/** + * \brief Returns if the transmit is blocking or not. + * FALSE - Non Blocking + * TRUE - Blocking +**/ + +BOOL uartX_tx_will_block(); + +/** + * \brief Returns how many more bytes can be loaded into the buffer. +**/ +BYTE uartX_tx_queue_len(); + +/** + * \brief Receives data through UART. + * Returns one byte at a time from the queue. +**/ +char uartX_rx(); + +/** + * \brief Returns if the receive is blocking or not. + * FALSE - Non Blocking + * TRUE - Blocking +**/ +BOOL uartX_rx_will_block(); + +/** + * \brief Returns count number of bytes present in the buffer. +**/ +BYTE uartX_rx_queue_len(); + +#endif