aboutsummaryrefslogtreecommitdiffstats
path: root/lib/hc32f460/driver/inc/hc32f460_usart.h
blob: ce5bd684d246c2af28659fd0788a26d876091263 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
/*******************************************************************************
 * Copyright (C) 2020, Huada Semiconductor Co., Ltd. All rights reserved.
 *
 * This software component is licensed by HDSC under BSD 3-Clause license
 * (the "License"); You may not use this file except in compliance with the
 * License. You may obtain a copy of the License at:
 *                    opensource.org/licenses/BSD-3-Clause
 */
/******************************************************************************/
/** \file hc32f460_usart.h
 **
 ** A detailed description is available at
 ** @link UsartGroup USART description @endlink
 **
 **   - 2018-11-27 CDT First version for Device Driver Library of USART.
 **
 ******************************************************************************/
#ifndef __HC32F460_USART_H__
#define __HC32F460_USART_H__

/*******************************************************************************
 * Include files
 ******************************************************************************/
#include "hc32_common.h"

/* C binding of definitions if building with C++ compiler */
#ifdef __cplusplus
extern "C"
{
#endif

/**
 *******************************************************************************
 ** \defgroup UsartGroup Universal Synchronous Asynchronous Receiver \
 **  Transmitter(USART)
 **
 ******************************************************************************/
//@{

/*******************************************************************************
 * Global type definitions ('typedef')
 ******************************************************************************/

/**
 *******************************************************************************
 ** \brief USART tx mode in multiple processor mode enumeration
 **
 ******************************************************************************/
typedef enum en_usart_mp_tx_mode
{
    UsartMpTxData = 0u,                     ///< USART Send data in multiple-processor mode
    UsartMpTxId   = 1u,                     ///< USART Send ID  in multiple-processor mode
} en_usart_mp_tx_mode_t;

/**
 *******************************************************************************
 ** \brief USART clock prescale enumeration
 **
 ******************************************************************************/
typedef enum en_usart_clk_div
{
    UsartClkDiv_1  = 0u,                    ///< PCLK/1
    UsartClkDiv_4  = 1u,                    ///< PCLK/4
    UsartClkDiv_16 = 2u,                    ///< PCLK/16
    UsartClkDiv_64 = 3u,                    ///< PCLK/64
} en_usart_clk_div_t;

/**
 ******************************************************************************
 ** \brief USART mode
 **
 ******************************************************************************/
typedef enum en_usart_mode
{
    UsartUartMode      = 0u,                ///< UART mode
    UsartClkSyncMode   = 1u,                ///< Clock sync mode
    UsartSmartCardMode = 2u,                ///< Smart card mode
} en_usart_mode_t;

/**
 ******************************************************************************
 ** \brief USART data direction
 **
 ******************************************************************************/
typedef enum en_usart_data_dir
{
    UsartDataLsbFirst = 0u,                 ///< LSB first
    UsartDataMsbFirst = 1u,                 ///< MSB first
} en_usart_data_dir_t;

/**
 ******************************************************************************
 ** \brief USART sample mode enumeration
 **
 ******************************************************************************/
typedef enum en_usart_sample_mode
{
    UsartSampleBit16 = 0u,                   ///< 16 Bit
    UsartSampleBit8  = 1u,                   ///< 8 Bit
} en_usart_sample_mode_t;

/**
 ******************************************************************************
 ** \brief USART data length enumeration
 **
 ******************************************************************************/
typedef enum en_usart_data_len
{
    UsartDataBits8 = 0u,                    ///< 8 Bit
    UsartDataBits9 = 1u,                    ///< 9 Bit
} en_usart_data_len_t;

/**
 ******************************************************************************
 ** \brief USART parity format enumeration
 **
 ******************************************************************************/
typedef enum en_usart_parity
{
    UsartParityNone = 0u,                   ///< No parity bit is used.
    UsartParityEven = 1u,                   ///< Even parity bit is used.
    UsartParityOdd  = 2u,                   ///< Odd parity bit is used.
} en_usart_parity_t;

/**
 ******************************************************************************
 ** \brief USART functions enumeration
 **
 ******************************************************************************/
typedef enum en_usart_func
{
    UsartRx              = 0u,              ///< UART RX function
    UsartRxInt           = 1u,              ///< USART RX interrupt function
    UsartTx              = 2u,              ///< UART TX function
    UsartTxEmptyInt      = 3u,              ///< USART TX empty interrupt function
    UsartTimeOut         = 4u,              ///< UART RX timeout function
    UsartTimeOutInt      = 5u,              ///< UART RX timeout interrupt function
    UsartSilentMode      = 6u,              ///< USART silent function
    UsartTxCmpltInt      = 7u,              ///< USART TX complete interrupt function
    UsartTxAndTxEmptyInt = 8u,              ///< USART TX function and USART TX empty interrupt function
    UsartParityCheck     = 9u,              ///< USART Parity check function
    UsartNoiseFilter     = 10u,             ///< USART noise filter function
    UsartFracBaudrate    = 11u,             ///< USART fractional baudrate function
    UsartMulProcessor    = 12u,             ///< USART multiple processor function
    UsartSmartCard       = 13u,             ///< USART smart card mode function
    UsartCts             = 14u,             ///< USART CTS function
} en_usart_func_t;

/**
 *******************************************************************************
 ** \brief USART status type enumeration
 **
 ******************************************************************************/
typedef enum en_usart_status
{
    UsartParityErr  = (1u << 0),            ///< USART parity error
    UsartFrameErr   = (1u << 1),            ///< USART receive frame error
    UsartOverrunErr = (1u << 3),            ///< USART receive over-run error
    UsartRxNoEmpty  = (1u << 5),            ///< USART data receive register is not empty
    UsartTxComplete = (1u << 6),            ///< USART transfer completely
    UsartTxEmpty    = (1u << 7),            ///< USART data transfer register is empty
    UsartRxTimeOut  = (1u << 8),            ///< USART data receive timeout
    UsartRxMpb      = (1u << 16),           ///< USART multiple processor id or normal data, 0: receive date; 1: received ID
} en_usart_status_t;

/**
 *******************************************************************************
 ** \brief USART Stop bit length select enumeration
 **
 ******************************************************************************/
typedef enum en_usart_stop_bit
{
    UsartOneStopBit = 0u,                   ///< 1 Stop Bit
    UsartTwoStopBit = 1u,                   ///< 2 Stop Bit
} en_usart_stop_bit_t;

/**
 *******************************************************************************
 ** \brief USART start bit detect mode enumeration
 **
 ******************************************************************************/
typedef enum en_usart_sb_detect_mode
{
    UsartStartBitLowLvl   = 0u,             ///< Start bit: RD pin low level
    UsartStartBitFallEdge = 1u,             ///< Start bit: RD pin falling edge
} en_usart_sb_detect_mode_t;

/**
 *******************************************************************************
 ** \brief USART clock mode selection enumeration
 **
 ******************************************************************************/
typedef enum en_usart_clk_mode
{
    UsartIntClkCkNoOutput = 0u,             ///< Select internal clock source and don't output clock.
    UsartIntClkCkOutput   = 1u,             ///< Select internal clock source and output clock.
    UsartExtClk           = 2u,             ///< Select external clock source.
} en_usart_clk_mode_t;

/**
 *******************************************************************************
 ** \brief USART smart-card mode selection enumeration
 **
 ******************************************************************************/
typedef enum en_usart_hw_flow_ctrl
{
    UsartRtsEnable = 0u,                    ///< Enable RTS function.
    UsartCtsEnable = 1u,                    ///< Enable CTS function.
} en_usart_hw_flow_ctrl_t;

/**
 ******************************************************************************
 ** \brief USART etu clocks of smart card enumeration
 **
 ******************************************************************************/
typedef enum en_usart_sc_etu_clk
{
    UsartScEtuClk32  = 0u,                  ///< 1 etu = 32/f
    UsartScEtuClk64  = 1u,                  ///< 1 etu = 64/f
    UsartScEtuClk128 = 3u,                  ///< 1 etu = 128/f
    UsartScEtuClk256 = 5u,                  ///< 1 etu = 256/f
    UsartScEtuClk372 = 6u,                  ///< 1 etu = 372/f
} en_usart_sc_etu_clk_t;

/**
 *******************************************************************************
 ** \brief Uart mode initialization configuration
 **
 ******************************************************************************/
typedef struct stc_usart_uart_init
{
    en_usart_clk_mode_t       enClkMode;        ///< Clock mode and this parameter can be a value of @ref en_usart_clk_mode_t

    en_usart_clk_div_t        enClkDiv;         ///< USART divide PCLK1, and this parameter can be a value of @ref en_usart_clk_div_t

    en_usart_data_len_t       enDataLength;     ///< 8/9 Bit character length and this parameter can be a value of @ref en_usart_data_len_t

    en_usart_data_dir_t       enDirection;      ///< UART data direction and this parameter can be a value of @ref en_usart_data_dir_t

    en_usart_stop_bit_t       enStopBit;        ///< Stop bit and this parameter can be a value of @ref en_usart_stop_bit_t

    en_usart_parity_t         enParity;         ///< Parity format and this parameter can be a value of @ref en_usart_parity_t

    en_usart_sample_mode_t    enSampleMode;     ///< USART sample mode, and this parameter can be a value of @ref en_usart_sample_mode_t

    en_usart_sb_detect_mode_t enDetectMode;     ///< USART start bit detect mode and this parameter can be a value of @ref en_usart_sb_detect_mode_t

    en_usart_hw_flow_ctrl_t   enHwFlow;         ///< Hardware flow control and this parameter can be a value of @ref en_usart_hw_flow_ctrl_t
} stc_usart_uart_init_t;

/**
 *******************************************************************************
 ** \brief Clock sync mode initialization configuration
 **
 ******************************************************************************/
typedef struct stc_usart_clksync_init
{
    en_usart_clk_mode_t       enClkMode;        ///< Clock mode and this parameter can be a value of @ref en_usart_clk_mode_t

    en_usart_clk_div_t        enClkDiv;         ///< USART divide PCLK1, and this parameter can be a value of @ref en_usart_clk_div_t

    en_usart_data_dir_t       enDirection;      ///< UART data direction and this parameter can be a value of @ref en_usart_data_dir_t

    en_usart_hw_flow_ctrl_t   enHwFlow;         ///< Hardware flow control and this parameter can be a value of @ref en_usart_hw_flow_ctrl_t
} stc_usart_clksync_init_t;

/**
 *******************************************************************************
 ** \brief Smart card mode initialization configuration
 **
 ******************************************************************************/
typedef struct stc_usart_sc_init
{
    en_usart_clk_mode_t       enClkMode;        ///< Clock mode and this parameter can be a value of @ref en_usart_clk_mode_t

    en_usart_clk_div_t        enClkDiv;         ///< USART divide PCLK1, and this parameter can be a value of @ref en_usart_clk_div_t

    en_usart_data_dir_t       enDirection;      ///< UART data direction and this parameter can be a value of @ref en_usart_data_dir_t
} stc_usart_sc_init_t;

/*******************************************************************************
 * Global pre-processor symbols/macros ('#define')
 ******************************************************************************/

/*******************************************************************************
 * Global variable definitions ('extern')
 ******************************************************************************/

/*******************************************************************************
 * Global function prototypes (definition in C source)
 ******************************************************************************/
en_result_t USART_UART_Init(M4_USART_TypeDef *USARTx,
                                const stc_usart_uart_init_t *pstcInitCfg);
en_result_t USART_CLKSYNC_Init(M4_USART_TypeDef *USARTx,
                                const stc_usart_clksync_init_t *pstcInitCfg);
en_result_t USART_SC_Init(M4_USART_TypeDef *USARTx,
                                const stc_usart_sc_init_t *pstcInitCfg);
en_result_t USART_DeInit(M4_USART_TypeDef *USARTx);
en_flag_status_t USART_GetStatus(M4_USART_TypeDef *USARTx,
                                en_usart_status_t enStatus);
en_result_t USART_ClearStatus(M4_USART_TypeDef *USARTx,
                                en_usart_status_t enStatus);
en_result_t USART_FuncCmd(M4_USART_TypeDef *USARTx,
                                en_usart_func_t enFunc,
                                en_functional_state_t enCmd);
en_result_t USART_SetParity(M4_USART_TypeDef *USARTx,
                                en_usart_parity_t enParity);
en_usart_parity_t USART_GetParity(M4_USART_TypeDef *USARTx);
en_result_t USART_SetOverSampling(M4_USART_TypeDef *USARTx,
                                en_usart_sample_mode_t enSampleMode);
en_usart_sample_mode_t USART_GetOverSampling(M4_USART_TypeDef *USARTx);
en_result_t USART_SetDataDirection(M4_USART_TypeDef *USARTx,
                                en_usart_data_dir_t enDir);
en_usart_data_dir_t USART_GetTransferDirection(M4_USART_TypeDef *USARTx);
en_result_t USART_SetDataLength(M4_USART_TypeDef *USARTx,
                                en_usart_data_len_t enDataLen);
en_usart_data_len_t USART_GetDataLength(M4_USART_TypeDef *USARTx);
en_result_t USART_SetClkMode(M4_USART_TypeDef *USARTx,
                                en_usart_clk_mode_t enClkMode);
en_usart_clk_mode_t USART_GetClkMode(M4_USART_TypeDef *USARTx);
en_result_t USART_SetMode(M4_USART_TypeDef *USARTx,
                                en_usart_mode_t enMode);
en_usart_mode_t USART_GetMode(M4_USART_TypeDef *USARTx);
en_result_t USART_SetStopBitsLength(M4_USART_TypeDef *USARTx,
                                en_usart_stop_bit_t enStopBit);
en_usart_stop_bit_t USART_GetStopBitsLength(M4_USART_TypeDef *USARTx);
en_result_t USART_SetSbDetectMode(M4_USART_TypeDef *USARTx,
                                en_usart_sb_detect_mode_t enDetectMode);
en_usart_sb_detect_mode_t USART_GetSbDetectMode(M4_USART_TypeDef *USARTx);
en_result_t USART_SetHwFlowCtrl(M4_USART_TypeDef *USARTx,
                                en_usart_hw_flow_ctrl_t enHwFlowCtrl);
en_usart_hw_flow_ctrl_t USART_GetHwFlowCtrl(M4_USART_TypeDef *USARTx);
en_result_t USART_SetClockDiv(M4_USART_TypeDef *USARTx,
                                en_usart_clk_div_t enClkPrescale);
en_usart_clk_div_t USART_GetClockDiv(M4_USART_TypeDef *USARTx);
en_result_t USART_SetScEtuClk(M4_USART_TypeDef *USARTx,
                                en_usart_sc_etu_clk_t enEtuClk);
en_usart_sc_etu_clk_t USART_GetScEtuClk(M4_USART_TypeDef *USARTx);
en_result_t USART_SendData(M4_USART_TypeDef *USARTx, uint16_t u16Data);
uint16_t USART_RecData(M4_USART_TypeDef *USARTx);
en_result_t USART_SetBaudrate(M4_USART_TypeDef *USARTx,
                                uint32_t u32Baudrate);

//@} // UsartGroup

#ifdef __cplusplus
}
#endif

#endif /* __HC32F460_USART_H__ */

/*******************************************************************************
 * EOF (not truncated)
 ******************************************************************************/