TI-RTOS Drivers  tidrivers_full_2_20_00_08
UARTTiva.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015, Texas Instruments Incorporated
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  *
12  * * Redistributions in binary form must reproduce the above copyright
13  * notice, this list of conditions and the following disclaimer in the
14  * documentation and/or other materials provided with the distribution.
15  *
16  * * Neither the name of Texas Instruments Incorporated nor the names of
17  * its contributors may be used to endorse or promote products derived
18  * from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
22  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
24  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
27  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
28  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
75 #ifndef ti_drivers_uart_UARTTiva__include
76 #define ti_drivers_uart_UARTTiva__include
77 
78 #ifdef __cplusplus
79 extern "C" {
80 #endif
81 
82 #include <stdint.h>
83 #include <stdbool.h>
84 #include <ti/drivers/UART.h>
86 
87 #include <ti/sysbios/knl/Clock.h>
88 #include <ti/sysbios/knl/Semaphore.h>
89 #define ti_sysbios_family_arm_m3_Hwi__nolocalnames
90 #include <ti/sysbios/family/arm/m3/Hwi.h>
91 
92 /* UART function table pointer */
93 extern const UART_FxnTable UARTTiva_fxnTable;
94 
116 typedef struct UARTTiva_FxnSet {
117  bool (*readIsrFxn) (UART_Handle handle);
118  int (*readTaskFxn) (UART_Handle handle);
120 
165 typedef struct UARTTiva_HWAttrs {
167  unsigned int baseAddr;
169  unsigned int intNum;
171  unsigned int intPriority;
173  uint32_t flowControl;
175  unsigned char *ringBufPtr;
177  size_t ringBufSize;
179 
185 typedef struct UARTTiva_Object {
186  /* UART state variable */
187  struct {
188  bool opened:1; /* Has the obj been opened */
189  UART_Mode readMode:1; /* Mode for all read calls */
190  UART_Mode writeMode:1; /* Mode for all write calls */
191  UART_DataMode readDataMode:1; /* Type of data being read */
192  UART_DataMode writeDataMode:1; /* Type of data being written */
193  UART_ReturnMode readReturnMode:1; /* Receive return mode */
194  UART_Echo readEcho:1; /* Echo received data back */
195  /*
196  * Flag to determine if a timeout has occurred when the user called
197  * UART_read(). This flag is set by the timeoutClk clock object.
198  */
199  bool bufTimeout:1;
200  /*
201  * Flag to determine when an ISR needs to perform a callback; in both
202  * UART_MODE_BLOCKING or UART_MODE_CALLBACK
203  */
204  bool callCallback:1;
205  /*
206  * Flag to determine if the ISR is in control draining the ring buffer
207  * when in UART_MODE_CALLBACK
208  */
209  bool drainByISR:1;
210  /* Flag to keep the state of the read ring buffer */
211  bool rxEnabled:1;
212  } state;
213 
214  Clock_Struct timeoutClk; /* Clock object to for timeouts */
215  uint32_t baudRate; /* Baud rate for UART */
216  UART_LEN dataLength; /* Data length for UART */
217  UART_STOP stopBits; /* Stop bits for UART */
218  UART_PAR parityType; /* Parity bit type for UART */
219 
220  /* UART read variables */
221  RingBuf_Object ringBuffer; /* local circular buffer object */
222  /* A complement pair of read functions for both the ISR and UART_read() */
224  unsigned char *readBuf; /* Buffer data pointer */
225  size_t readSize; /* Desired number of bytes to read */
226  size_t readCount; /* Number of bytes left to read */
227  Semaphore_Struct readSem; /* UART read semaphore */
228  unsigned int readTimeout; /* Timeout for read semaphore */
229  UART_Callback readCallback; /* Pointer to read callback */
230 
231  /* UART write variables */
232  const unsigned char *writeBuf; /* Buffer data pointer */
233  size_t writeSize; /* Desired number of bytes to write*/
234  size_t writeCount; /* Number of bytes left to write */
235  Semaphore_Struct writeSem; /* UART write semaphore*/
236  unsigned int writeTimeout; /* Timeout for write semaphore */
237  UART_Callback writeCallback; /* Pointer to write callback */
238 
239  ti_sysbios_family_arm_m3_Hwi_Struct hwi; /* Hwi object */
241 
242 /* Do not interfere with the app if they include the family Hwi module */
243 #undef ti_sysbios_family_arm_m3_Hwi__nolocalnames
244 
245 #ifdef __cplusplus
246 }
247 #endif
248 
249 #endif /* ti_drivers_uart_UARTTiva__include */
struct UARTTiva_Object UARTTiva_Object
UARTTiva Object.
UARTTiva Object.
Definition: UARTTiva.h:185
UART_STOP
UART stop bit settings.
Definition: UART.h:410
UART_STOP stopBits
Definition: UARTTiva.h:217
struct UARTTiva_HWAttrs UARTTiva_HWAttrs
UARTTiva Hardware attributes.
unsigned char * readBuf
Definition: UARTTiva.h:224
size_t writeCount
Definition: UARTTiva.h:234
UART_Mode readMode
Definition: UARTTiva.h:189
struct UARTTiva_Object::@7 state
uint32_t baudRate
Definition: UARTTiva.h:215
UART_LEN dataLength
Definition: UARTTiva.h:216
UARTTiva_FxnSet readFxns
Definition: UARTTiva.h:223
The definition of a UART function table that contains the required set of functions to control a spec...
Definition: UART.h:528
size_t ringBufSize
Definition: UARTTiva.h:177
UART_PAR
UART parity type settings.
Definition: UART.h:420
UART_Mode
UART mode settings.
Definition: UART.h:322
UART_DataMode
UART data mode settings.
Definition: UART.h:370
unsigned int intPriority
Definition: UARTTiva.h:171
size_t readCount
Definition: UARTTiva.h:226
bool opened
Definition: UARTTiva.h:188
UART_ReturnMode
UART return mode settings.
Definition: UART.h:355
size_t writeSize
Definition: UARTTiva.h:233
Semaphore_Struct readSem
Definition: UARTTiva.h:227
UART_Callback readCallback
Definition: UARTTiva.h:229
UART_Echo
UART echo settings.
Definition: UART.h:388
bool(* readIsrFxn)(UART_Handle handle)
Definition: UARTTiva.h:117
UART_DataMode readDataMode
Definition: UARTTiva.h:191
UART_Echo readEcho
Definition: UARTTiva.h:194
UARTTiva Hardware attributes.
Definition: UARTTiva.h:165
int(* readTaskFxn)(UART_Handle handle)
Definition: UARTTiva.h:118
unsigned int readTimeout
Definition: UARTTiva.h:228
UART_Mode writeMode
Definition: UARTTiva.h:190
unsigned int baseAddr
Definition: UARTTiva.h:167
bool rxEnabled
Definition: UARTTiva.h:211
UART_PAR parityType
Definition: UARTTiva.h:218
Clock_Struct timeoutClk
Definition: UARTTiva.h:214
unsigned char * ringBufPtr
Definition: UARTTiva.h:175
const UART_FxnTable UARTTiva_fxnTable
UART driver interface.
unsigned int intNum
Definition: UARTTiva.h:169
size_t readSize
Definition: UARTTiva.h:225
struct UARTTiva_Object * UARTTiva_Handle
const unsigned char * writeBuf
Definition: UARTTiva.h:232
void(* UART_Callback)(UART_Handle, void *buf, size_t count)
The definition of a callback function used by the UART driver when used in UART_MODE_CALLBACK The cal...
Definition: UART.h:315
UART_ReturnMode readReturnMode
Definition: UARTTiva.h:193
unsigned int writeTimeout
Definition: UARTTiva.h:236
Complement set of read functions to be used by the UART ISR and UARTTiva_read(). Internal use only...
Definition: UARTTiva.h:116
Definition: RingBuf.h:44
UART_LEN
UART data length settings.
Definition: UART.h:398
bool drainByISR
Definition: UARTTiva.h:209
ti_sysbios_family_arm_m3_Hwi_Struct hwi
Definition: UARTTiva.h:239
struct UARTTiva_FxnSet UARTTiva_FxnSet
Complement set of read functions to be used by the UART ISR and UARTTiva_read(). Internal use only...
UART_Callback writeCallback
Definition: UARTTiva.h:237
Semaphore_Struct writeSem
Definition: UARTTiva.h:235
uint32_t flowControl
Definition: UARTTiva.h:173
bool bufTimeout
Definition: UARTTiva.h:199
RingBuf_Object ringBuffer
Definition: UARTTiva.h:221
UART_DataMode writeDataMode
Definition: UARTTiva.h:192
UART Global configuration.
Definition: UART.h:571
bool callCallback
Definition: UARTTiva.h:204
Copyright 2016, Texas Instruments Incorporated