RTEMS 7.0-rc1
Loading...
Searching...
No Matches
uart_dma.h
Go to the documentation of this file.
1/* ---------------------------------------------------------------------------- */
2/* Atmel Microcontroller Software Support */
3/* SAM Software Package License */
4/* ---------------------------------------------------------------------------- */
5/* Copyright (c) 2015, Atmel Corporation */
6/* */
7/* All rights reserved. */
8/* */
9/* Redistribution and use in source and binary forms, with or without */
10/* modification, are permitted provided that the following condition is met: */
11/* */
12/* - Redistributions of source code must retain the above copyright notice, */
13/* this list of conditions and the disclaimer below. */
14/* */
15/* Atmel's name may not be used to endorse or promote products derived from */
16/* this software without specific prior written permission. */
17/* */
18/* DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR */
19/* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF */
20/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE */
21/* DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, */
22/* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT */
23/* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, */
24/* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF */
25/* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING */
26/* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, */
27/* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
28/* ---------------------------------------------------------------------------- */
29
37#ifndef _UART_DMA_
38#define _UART_DMA_
39
40/*----------------------------------------------------------------------------
41 * Headers
42 *----------------------------------------------------------------------------*/
43
44#include "chip.h"
45
46/*----------------------------------------------------------------------------
47 * Definitions
48 *----------------------------------------------------------------------------*/
49
51#define UARTD_ERROR 1
52
54#define UARTD_ERROR_LOCK 2
55
56
57#ifdef __cplusplus
58extern "C" {
59#endif
60
61/*----------------------------------------------------------------------------
62 * Types
63 *----------------------------------------------------------------------------*/
64
66#ifdef __rtems__
68#else
69typedef void (*UartdCallback)(uint8_t, void *);
70#endif
71
77typedef struct {
79 uint8_t *pBuff;
81 uint32_t BuffSize;
83 uint32_t ChNum;
87 void *pArgument;
89 volatile uint8_t sempaphore;
90 /* DMA LLI structure */
92 /* DMA transfer type */
93 eXdmadProgState dmaProgrammingMode;
94 /* DMA LLI size */
95 uint16_t dmaBlockSize;
96 /* Flag using ring buffer or FiFo*/
97 uint8_t dmaRingBuffer;
99
102typedef struct {
104 uint8_t uartId;
113} UartDma;
114
115/*----------------------------------------------------------------------------
116 * Exported functions
117 *----------------------------------------------------------------------------*/
118
119uint32_t UARTD_Configure(UartDma *pUartd ,
120 uint8_t uartId,
121 uint32_t uartMode,
122 uint32_t baud,
123 uint32_t clk);
124
125uint32_t UARTD_EnableTxChannels(UartDma *pUartd, UartChannel *pTxCh);
126
127uint32_t UARTD_EnableRxChannels(UartDma *pUartd, UartChannel *pRxCh);
128
129uint32_t UARTD_DisableTxChannels(UartDma *pUartd, UartChannel *pTxCh);
130
131uint32_t UARTD_DisableRxChannels(UartDma *pUartd, UartChannel *pRxCh);
132
133uint32_t UARTD_SendData(UartDma *pUartd);
134
135uint32_t UARTD_RcvData(UartDma *pUartd);
136
137#ifdef __cplusplus
138}
139#endif
140
141#endif /* #ifndef _UART_DMA_ */
enum _XdmadProgState eXdmadProgState
void(* XdmadTransferCallback)(uint32_t Channel, void *pArg, uint32_t status)
Definition: xdmad.h:110
Chip definitions for STM32U5.
usart Transfer Request prepared by the application upper layer.
Definition: uart_dma.h:77
void * pArgument
Definition: uart_dma.h:87
UartdCallback callback
Definition: uart_dma.h:85
uint32_t BuffSize
Definition: uart_dma.h:81
volatile uint8_t sempaphore
Definition: uart_dma.h:89
uint8_t * pBuff
Definition: uart_dma.h:79
uint32_t ChNum
Definition: uart_dma.h:83
Definition: uart_dma.h:102
Uart * pUartHw
Definition: uart_dma.h:108
UartChannel * pTxChannel
Definition: uart_dma.h:112
UartChannel * pRxChannel
Definition: uart_dma.h:110
sXdmad * pXdmad
Definition: uart_dma.h:106
uint8_t uartId
Definition: uart_dma.h:104
Uart hardware registers.
Definition: component_uart.h:41
Structure for storing parameters for DMA view1 that can be performed by the DMA Master transfer.
Definition: xdmad.h:167
Definition: xdmad.h:127
uint32_t UARTD_DisableRxChannels(UartDma *pUartd, UartChannel *pRxCh)
This function disables the appropriate DMA channel for Rx channel of USART.
Definition: uart_dma.c:527
void(* UartdCallback)(uint8_t, void *)
Definition: uart_dma.h:69
uint32_t UARTD_SendData(UartDma *pUartd)
Starts a UART master transfer. This is a non blocking function. It will return as soon as the transfe...
Definition: uart_dma.c:595
uint32_t UARTD_EnableRxChannels(UartDma *pUartd, UartChannel *pRxCh)
This function initialize the appropriate DMA channel for Rx channel of UART.
Definition: uart_dma.c:419
uint32_t UARTD_EnableTxChannels(UartDma *pUartd, UartChannel *pTxCh)
This function initialize the appropriate DMA channel for Tx channel of UART.
Definition: uart_dma.c:474
uint32_t UARTD_Configure(UartDma *pUartd, uint8_t uartId, uint32_t uartMode, uint32_t baud, uint32_t clk)
Initializes the UartDma structure and the corresponding UART & DMA . hardware select value....
Definition: uart_dma.c:370
uint32_t UARTD_DisableTxChannels(UartDma *pUartd, UartChannel *pTxCh)
This function disables the appropriate DMA channel for Tx channel of USART.
Definition: uart_dma.c:562
uint32_t UARTD_RcvData(UartDma *pUartd)
Starts a UART master transfer. This is a non blocking function. It will return as soon as the transfe...
Definition: uart_dma.c:617