xref: /btstack/port/renesas-ek-ra6m4a-da14531/e2-project/ra/fsp/inc/instances/r_sci_uart.h (revision c30869498fb8e98c1408c9db0e7624f02f483b73)
1 /***********************************************************************************************************************
2  * Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates.  All Rights Reserved.
3  *
4  * This software and documentation are supplied by Renesas Electronics America Inc. and may only be used with products
5  * of Renesas Electronics Corp. and its affiliates ("Renesas").  No other uses are authorized.  Renesas products are
6  * sold pursuant to Renesas terms and conditions of sale.  Purchasers are solely responsible for the selection and use
7  * of Renesas products and Renesas assumes no liability.  No license, express or implied, to any intellectual property
8  * right is granted by Renesas. This software is protected under all applicable laws, including copyright laws. Renesas
9  * reserves the right to change or discontinue this software and/or this documentation. THE SOFTWARE AND DOCUMENTATION
10  * IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND TO THE FULLEST EXTENT
11  * PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY, INCLUDING WARRANTIES
12  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE SOFTWARE OR
13  * DOCUMENTATION.  RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.  TO THE MAXIMUM
14  * EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR DOCUMENTATION
15  * (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER, INCLUDING,
16  * WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY LOST PROFITS,
17  * OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE POSSIBILITY
18  * OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
19  **********************************************************************************************************************/
20 
21 #ifndef R_SCI_UART_H
22 #define R_SCI_UART_H
23 
24 /*******************************************************************************************************************//**
25  * @addtogroup SCI_UART
26  * @{
27  **********************************************************************************************************************/
28 
29 /***********************************************************************************************************************
30  * Includes
31  **********************************************************************************************************************/
32 #include "bsp_api.h"
33 #include "r_uart_api.h"
34 #include "r_sci_uart_cfg.h"
35 
36 /* Common macro for FSP header files. There is also a corresponding FSP_FOOTER macro at the end of this file. */
37 FSP_HEADER
38 
39 /***********************************************************************************************************************
40  * Macro definitions
41  **********************************************************************************************************************/
42 
43 /**********************************************************************************************************************
44  * Typedef definitions
45  **********************************************************************************************************************/
46 
47 /** Enumeration for SCI clock source */
48 typedef enum e_sci_clk_src
49 {
50     SCI_UART_CLOCK_INT,                      ///< Use internal clock for baud generation
51     SCI_UART_CLOCK_INT_WITH_BAUDRATE_OUTPUT, ///< Use internal clock for baud generation and output on SCK
52     SCI_UART_CLOCK_EXT8X,                    ///< Use external clock 8x baud rate
53     SCI_UART_CLOCK_EXT16X                    ///< Use external clock 16x baud rate
54 } sci_clk_src_t;
55 
56 /** UART flow control mode definition */
57 typedef enum e_sci_uart_flow_control
58 {
59     SCI_UART_FLOW_CONTROL_RTS             = 0U, ///< Use SCI pin for RTS
60     SCI_UART_FLOW_CONTROL_CTS             = 1U, ///< Use SCI pin for CTS
61     SCI_UART_FLOW_CONTROL_CTSRTS          = 3U, ///< Use SCI pin for CTS, external pin for RTS
62     SCI_UART_FLOW_CONTROL_HARDWARE_CTSRTS = 8U, ///< Use CTSn_RTSn pin for RTS and CTSn pin for CTS. Available only for some channels on selected MCUs. See hardware manual for channel specific options
63 } sci_uart_flow_control_t;
64 
65 /** UART instance control block. */
66 typedef struct st_sci_uart_instance_ctrl
67 {
68     /* Parameters to control UART peripheral device */
69     uint8_t  fifo_depth;               // FIFO depth of the UART channel
70     uint8_t  rx_transfer_in_progress;  // Set to 1 if a receive transfer is in progress, 0 otherwise
71     uint8_t  data_bytes         : 2;   // 1 byte for 7 or 8 bit data, 2 bytes for 9 bit data
72     uint8_t  bitrate_modulation : 1;   // 1 if bit rate modulation is enabled, 0 otherwise
73     uint32_t open;                     // Used to determine if the channel is configured
74 
75     bsp_io_port_pin_t flow_pin;
76 
77     /* Source buffer pointer used to fill hardware FIFO from transmit ISR. */
78     uint8_t const * p_tx_src;
79 
80     /* Size of source buffer pointer used to fill hardware FIFO from transmit ISR. */
81     uint32_t tx_src_bytes;
82 
83     /* Destination buffer pointer used for receiving data. */
84     uint8_t const * p_rx_dest;
85 
86     /* Size of destination buffer pointer used for receiving data. */
87     uint32_t rx_dest_bytes;
88 
89     /* Pointer to the configuration block. */
90     uart_cfg_t const * p_cfg;
91 
92     /* Base register for this channel */
93     R_SCI0_Type * p_reg;
94 
95     void (* p_callback)(uart_callback_args_t *); // Pointer to callback that is called when a uart_event_t occurs.
96     uart_callback_args_t * p_callback_memory;    // Pointer to non-secure memory that can be used to pass arguments to a callback in non-secure memory.
97 
98     /* Pointer to context to be passed into callback function */
99     void const * p_context;
100 } sci_uart_instance_ctrl_t;
101 
102 /** Receive FIFO trigger configuration. */
103 typedef enum e_sci_uart_rx_fifo_trigger
104 {
105     SCI_UART_RX_FIFO_TRIGGER_1   = 0x1, ///< Callback after each byte is received without buffering
106     SCI_UART_RX_FIFO_TRIGGER_MAX = 0xF, ///< Callback when FIFO is full or after 15 bit times with no data (fewer interrupts)
107 } sci_uart_rx_fifo_trigger_t;
108 
109 /** Asynchronous Start Bit Edge Detection configuration. */
110 typedef enum e_sci_uart_start_bit_detect
111 {
112     SCI_UART_START_BIT_LOW_LEVEL    = 0x0, ///< Detect low level on RXDn pin as start bit
113     SCI_UART_START_BIT_FALLING_EDGE = 0x1, ///< Detect falling level on RXDn pin as start bit
114 } sci_uart_start_bit_detect_t;
115 
116 /** Noise cancellation configuration. */
117 typedef enum e_sci_uart_noise_cancellation
118 {
119     SCI_UART_NOISE_CANCELLATION_DISABLE = 0x0, ///< Disable noise cancellation
120     SCI_UART_NOISE_CANCELLATION_ENABLE  = 0x1, ///< Enable noise cancellation
121 } sci_uart_noise_cancellation_t;
122 
123 /** RS-485 Enable/Disable. */
124 typedef enum e_sci_uart_rs485_enable
125 {
126     SCI_UART_RS485_DISABLE = 0,        ///< RS-485 disabled.
127     SCI_UART_RS485_ENABLE  = 1,        ///< RS-485 enabled.
128 } sci_uart_rs485_enable_t;
129 
130 /** The polarity of the RS-485 DE signal. */
131 typedef enum e_sci_uart_rs485_de_polarity
132 {
133     SCI_UART_RS485_DE_POLARITY_HIGH = 0, ///< The DE signal is high when a write transfer is in progress.
134     SCI_UART_RS485_DE_POLARITY_LOW  = 1, ///< The DE signal is low when a write transfer is in progress.
135 } sci_uart_rs485_de_polarity_t;
136 
137 /** Register settings to acheive a desired baud rate and modulation duty. */
138 typedef struct st_baud_setting_t
139 {
140     union
141     {
142         uint8_t semr_baudrate_bits;
143 
144         /* DEPRECATED: Anonymous structure. */
145         struct
146         {
147             uint8_t       : 2;
148             uint8_t brme  : 1;         ///< Bit Rate Modulation Enable
149             uint8_t abcse : 1;         ///< Asynchronous Mode Extended Base Clock Select 1
150             uint8_t abcs  : 1;         ///< Asynchronous Mode Base Clock Select
151             uint8_t       : 1;
152             uint8_t bgdm  : 1;         ///< Baud Rate Generator Double-Speed Mode Select
153             uint8_t       : 1;
154         };
155 
156         struct
157         {
158             uint8_t       : 2;
159             uint8_t brme  : 1;         ///< Bit Rate Modulation Enable
160             uint8_t abcse : 1;         ///< Asynchronous Mode Extended Base Clock Select 1
161             uint8_t abcs  : 1;         ///< Asynchronous Mode Base Clock Select
162             uint8_t       : 1;
163             uint8_t bgdm  : 1;         ///< Baud Rate Generator Double-Speed Mode Select
164             uint8_t       : 1;
165         } semr_baudrate_bits_b;
166     };
167     uint8_t cks : 2;                   ///< CKS  value to get divisor (CKS = N)
168     uint8_t brr;                       ///< Bit Rate Register setting
169     uint8_t mddr;                      ///< Modulation Duty Register setting
170 } baud_setting_t;
171 
172 /** Configuration settings for controlling the DE signal for RS-485. */
173 typedef struct st_sci_uart_rs485_setting
174 {
175     sci_uart_rs485_enable_t      enable;         ///< Enable the DE signal.
176     sci_uart_rs485_de_polarity_t polarity;       ///< DE signal polarity.
177     bsp_io_port_pin_t            de_control_pin; ///< UART Driver Enable pin.
178 } sci_uart_rs485_setting_t;
179 
180 /** UART on SCI device Configuration */
181 typedef struct st_sci_uart_extended_cfg
182 {
183     sci_clk_src_t                 clock;            ///< The source clock for the baud-rate generator. If internal optionally output baud rate on SCK
184     sci_uart_start_bit_detect_t   rx_edge_start;    ///< Start reception on falling edge
185     sci_uart_noise_cancellation_t noise_cancel;     ///< Noise cancellation setting
186     baud_setting_t              * p_baud_setting;   ///< Register settings for a desired baud rate.
187     sci_uart_rx_fifo_trigger_t    rx_fifo_trigger;  ///< Receive FIFO trigger level, unused if channel has no FIFO or if DTC is used.
188     bsp_io_port_pin_t             flow_control_pin; ///< UART Driver Enable pin
189     sci_uart_flow_control_t       flow_control;     ///< CTS/RTS function of the SSn pin
190     sci_uart_rs485_setting_t      rs485_setting;    ///< RS-485 settings.
191 } sci_uart_extended_cfg_t;
192 
193 /**********************************************************************************************************************
194  * Exported global variables
195  **********************************************************************************************************************/
196 
197 /** @cond INC_HEADER_DEFS_SEC */
198 /** Filled in Interface API structure for this Instance. */
199 extern const uart_api_t g_uart_on_sci;
200 
201 /** @endcond */
202 
203 fsp_err_t R_SCI_UART_Open(uart_ctrl_t * const p_api_ctrl, uart_cfg_t const * const p_cfg);
204 fsp_err_t R_SCI_UART_Read(uart_ctrl_t * const p_api_ctrl, uint8_t * const p_dest, uint32_t const bytes);
205 fsp_err_t R_SCI_UART_Write(uart_ctrl_t * const p_api_ctrl, uint8_t const * const p_src, uint32_t const bytes);
206 fsp_err_t R_SCI_UART_BaudSet(uart_ctrl_t * const p_api_ctrl, void const * const p_baud_setting);
207 fsp_err_t R_SCI_UART_InfoGet(uart_ctrl_t * const p_api_ctrl, uart_info_t * const p_info);
208 fsp_err_t R_SCI_UART_Close(uart_ctrl_t * const p_api_ctrl);
209 fsp_err_t R_SCI_UART_Abort(uart_ctrl_t * const p_api_ctrl, uart_dir_t communication_to_abort);
210 fsp_err_t R_SCI_UART_BaudCalculate(uint32_t               baudrate,
211                                    bool                   bitrate_modulation,
212                                    uint32_t               baud_rate_error_x_1000,
213                                    baud_setting_t * const p_baud_setting);
214 fsp_err_t R_SCI_UART_CallbackSet(uart_ctrl_t * const          p_api_ctrl,
215                                  void (                     * p_callback)(uart_callback_args_t *),
216                                  void const * const           p_context,
217                                  uart_callback_args_t * const p_callback_memory);
218 fsp_err_t R_SCI_UART_ReadStop(uart_ctrl_t * const p_api_ctrl, uint32_t * remaining_bytes);
219 
220 /*******************************************************************************************************************//**
221  * @} (end addtogroup SCI_UART)
222  **********************************************************************************************************************/
223 
224 /* Common macro for FSP header files. There is also a corresponding FSP_HEADER macro at the top of this file. */
225 FSP_FOOTER
226 
227 #endif
228