232 lines
7.0 KiB
C
232 lines
7.0 KiB
C
|
|
/*********************************************************************************************************************
|
|||
|
|
* CH32V307VCT6 Opensourec Library <EFBFBD><EFBFBD><EFBFBD><EFBFBD>CH32V307VCT6 <EFBFBD><EFBFBD>Դ<EFBFBD>⣩<EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڹٷ<EFBFBD> SDK <EFBFBD>ӿڵĵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD>
|
|||
|
|
* Copyright (c) 2022 SEEKFREE <EFBFBD><EFBFBD><EFBFBD>ɿƼ<EFBFBD>
|
|||
|
|
*
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD>CH32V307VCT6 <EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
*
|
|||
|
|
* CH32V307VCT6 <EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ը<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ᷢ<EFBFBD><EFBFBD><EFBFBD><EFBFBD> GPL<EFBFBD><EFBFBD>GNU General Public License<EFBFBD><EFBFBD><EFBFBD><EFBFBD> GNUͨ<EFBFBD>ù<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>֤<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
* <EFBFBD><EFBFBD> GPL <EFBFBD>ĵ<EFBFBD>3<EFBFBD>棨<EFBFBD><EFBFBD> GPL3.0<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѡ<EFBFBD><EFBFBD><EFBFBD>ģ<EFBFBD><EFBFBD>κκ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>İ汾<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>/<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
*
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD><EFBFBD>ķ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ܷ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ã<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>κεı<EFBFBD>֤
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ի<EFBFBD><EFBFBD>ʺ<EFBFBD><EFBFBD>ض<EFBFBD><EFBFBD><EFBFBD>;<EFBFBD>ı<EFBFBD>֤
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϸ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>μ<EFBFBD> GPL
|
|||
|
|
*
|
|||
|
|
* <EFBFBD><EFBFBD>Ӧ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>յ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͬʱ<EFBFBD>յ<EFBFBD>һ<EFBFBD><EFBFBD> GPL <EFBFBD>ĸ<EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD>У<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><https://www.gnu.org/licenses/>
|
|||
|
|
*
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ע<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD>ʹ<EFBFBD><EFBFBD> GPL3.0 <EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>֤Э<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><EFBFBD><EFBFBD>İ汾
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ӣ<EFBFBD>İ<EFBFBD><EFBFBD><EFBFBD> libraries/doc <EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>µ<EFBFBD> GPL3_permission_statement.txt <EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>֤<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> libraries <EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>µ<EFBFBD> LICENSE <EFBFBD>ļ<EFBFBD>
|
|||
|
|
* <EFBFBD><EFBFBD>ӭ<EFBFBD><EFBFBD>λʹ<EFBFBD>ò<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD>뱣<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɿƼ<EFBFBD><EFBFBD>İ<EFBFBD>Ȩ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
*
|
|||
|
|
* <EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> zf_driver_uart
|
|||
|
|
* <EFBFBD><EFBFBD>˾<EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD>ɶ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɿƼ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˾
|
|||
|
|
* <EFBFBD>汾<EFBFBD><EFBFBD>Ϣ <EFBFBD>鿴 libraries/doc <EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> version <EFBFBD>ļ<EFBFBD> <EFBFBD>汾˵<EFBFBD><EFBFBD>
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> MounRiver Studio V1.8.1
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƽ̨ CH32V307VCT6
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> https://seekfree.taobao.com/
|
|||
|
|
*
|
|||
|
|
* <EFBFBD>ļ<EFBFBD>¼
|
|||
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD>ע
|
|||
|
|
* 2022-09-15 <EFBFBD><EFBFBD>W first version
|
|||
|
|
********************************************************************************************************************/
|
|||
|
|
|
|||
|
|
#ifndef _zf_driver_uart_h
|
|||
|
|
#define _zf_driver_uart_h
|
|||
|
|
|
|||
|
|
#include "ch32v30x.h"
|
|||
|
|
#include "ch32v30x_gpio.h"
|
|||
|
|
#include "ch32v30x_rcc.h"
|
|||
|
|
#include "ch32v30x_usart.h"
|
|||
|
|
|
|||
|
|
#include "zf_common_interrupt.h"
|
|||
|
|
#include "zf_common_debug.h"
|
|||
|
|
#include "zf_driver_gpio.h"
|
|||
|
|
|
|||
|
|
// <20><>ö<EFBFBD>ٶ<EFBFBD><D9B6>岻<EFBFBD><E5B2BB><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD>
|
|||
|
|
// <20><>ʼ<EFBFBD><CABC><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><F2A3ACB1><EFBFBD>ʹ<EFBFBD><CAB9>ͬһ<CDAC><D2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>磬UART1_MAP_TX_A9<41><39>UART1_MAP_RX_A10<31><30>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
//
|
|||
|
|
typedef enum // <20><>ö<EFBFBD>ٶ<EFBFBD><D9B6>岻<EFBFBD><E5B2BB><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD>
|
|||
|
|
{
|
|||
|
|
// MAP0 Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
// MAP1 <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
// MAP2 <20><><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3>
|
|||
|
|
// MAP3 <20><>ȫӳ<C8AB><D3B3>
|
|||
|
|
|
|||
|
|
//----------UART1-----------//
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>1<EFBFBD><31>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><><EFBFBD>磺UART1_MAP0_TX_A9<41><39>UART1_MAP1_TX_B6<42><36><EFBFBD><EFBFBD>һ<EFBFBD><D2BB>ʹ<EFBFBD>á<EFBFBD>
|
|||
|
|
|
|||
|
|
// Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART1_MAP0_TX_A9 = 0x0000 | A9 ,
|
|||
|
|
UART1_MAP0_RX_A10 = 0x0000 | A10,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>1<EFBFBD><31>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART1_MAP1_TX_B6 = 0x0100 | B6 ,
|
|||
|
|
UART1_MAP1_RX_B7 = 0x0100 | B7 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>1<EFBFBD><31>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART1_MAP2_TX_B15 = 0x0200 | B15,
|
|||
|
|
UART1_MAP2_RX_A8 = 0x0200 | A8 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>1<EFBFBD><31>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ȫӳ<C8AB><D3B3>
|
|||
|
|
UART1_MAP3_TX_A6 = 0x0300 | A6 ,
|
|||
|
|
UART1_MAP3_RX_A7 = 0x0300 | A7 ,
|
|||
|
|
|
|||
|
|
//----------UART2-----------//
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>2<EFBFBD><32>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART2_MAP0_TX_A2 = 0x1000 | A2 ,
|
|||
|
|
UART2_MAP0_RX_A3 = 0x1000 | A3 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>2<EFBFBD><32>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART2_MAP1_TX_D5 = 0x1100 | D5 ,
|
|||
|
|
UART2_MAP1_RX_D6 = 0x1100 | D6 ,
|
|||
|
|
|
|||
|
|
//----------UART3--------------//
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>3<EFBFBD><33>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART3_MAP0_TX_B10 = 0x2000 | B10, // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ĭ<EFBFBD><C4AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
UART3_MAP0_RX_B11 = 0x2000 | B11, // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ĭ<EFBFBD><C4AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>3<EFBFBD><33>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART3_MAP1_TX_C10 = 0x2100 | C10,
|
|||
|
|
UART3_MAP1_RX_C11 = 0x2100 | C11,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>3<EFBFBD><33>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ȫӳ<C8AB><D3B3>
|
|||
|
|
UART3_MAP2_TX_D8 = 0x2300 | D8 ,
|
|||
|
|
UART3_MAP2_RX_D9 = 0x2300 | D9 ,
|
|||
|
|
|
|||
|
|
//----------UART4-----------//
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>4<EFBFBD><34>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART4_MAP0_TX_C10 = 0x3000 | C10,
|
|||
|
|
UART4_MAP0_RX_C11 = 0x3000 | C11,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>4<EFBFBD><34>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART4_MAP1_TX_B0 = 0x3100 | B0 ,
|
|||
|
|
UART4_MAP1_RX_B1 = 0x3100 | B1 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>4<EFBFBD><34>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ȫӳ<C8AB><D3B3>
|
|||
|
|
UART4_MAP3_TX_E0 = 0x3300 | E0 ,
|
|||
|
|
UART4_MAP3_RX_E1 = 0x3300 | E1 ,
|
|||
|
|
|
|||
|
|
//----------UART5-----------//
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>5<EFBFBD><35>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART5_MAP0_TX_C12 = 0x4000 | C12,
|
|||
|
|
UART5_MAP0_RX_D2 = 0x4000 | D2,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>5<EFBFBD><35>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART5_MAP1_TX_B4 = 0x4100 | B4,
|
|||
|
|
UART5_MAP1_RX_B5 = 0x4100 | B5,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>5<EFBFBD><35>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ȫӳ<C8AB><D3B3>
|
|||
|
|
UART5_MAP3_TX_E8 = 0x4300 | E8,
|
|||
|
|
UART5_MAP3_RX_E9 = 0x4300 | E9,
|
|||
|
|
|
|||
|
|
//----------UART6-----------//
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>6<EFBFBD><36>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART6_MAP0_TX_C0 = 0x5000 | C0 ,
|
|||
|
|
UART6_MAP0_RX_C1 = 0x5000 | C1 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>6<EFBFBD><36>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART6_MAP1_TX_B8 = 0x5100 | B8 ,
|
|||
|
|
UART6_MAP1_RX_B9 = 0x5100 | B9 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>6<EFBFBD><36>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ȫӳ<C8AB><D3B3>
|
|||
|
|
UART6_MAP3_TX_E10 = 0x5300 | E10,
|
|||
|
|
UART6_MAP3_RX_E11 = 0x5300 | E11,
|
|||
|
|
|
|||
|
|
//----------UART7-----------//
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>7<EFBFBD><37>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART7_MAP0_TX_C2 = 0x6000 | C2 ,
|
|||
|
|
UART7_MAP0_RX_C3 = 0x6000 | C3 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>7<EFBFBD><37>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART7_MAP1_TX_A6 = 0x6100 | A6 ,
|
|||
|
|
UART7_MAP1_RX_A7 = 0x6100 | A7 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>7<EFBFBD><37>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ȫӳ<C8AB><D3B3>
|
|||
|
|
UART7_MAP3_TX_E12 = 0x6300 | E12,
|
|||
|
|
UART7_MAP3_RX_E13 = 0x6300 | E13,
|
|||
|
|
|
|||
|
|
//----------UART8-----------//
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>8<EFBFBD><38>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// Ĭ<><C4AC>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART8_MAP0_TX_C4 = 0x7000 | C4 ,
|
|||
|
|
UART8_MAP0_RX_C5 = 0x7000 | C5 ,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>8<EFBFBD><38>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ӳ<EFBFBD><D3B3>
|
|||
|
|
UART8_MAP1_TX_A14 = 0x7100 | A14,
|
|||
|
|
UART8_MAP1_RX_A15 = 0x7100 | A15,
|
|||
|
|
|
|||
|
|
// <20><><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD>8<EFBFBD><38>һ<EFBFBD><D2BB>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>ţ<EFBFBD><C5A3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD><D3B3><EFBFBD><EFBFBD><EFBFBD>Ż<EFBFBD><C5BB>á<EFBFBD>
|
|||
|
|
// <20><>ȫӳ<C8AB><D3B3>
|
|||
|
|
UART8_MAP3_TX_E14 = 0x7300 | E14,
|
|||
|
|
UART8_MAP3_RX_E15 = 0x7300 | E15,
|
|||
|
|
|
|||
|
|
}uart_pin_enum;
|
|||
|
|
|
|||
|
|
|
|||
|
|
typedef enum// <20><>ö<EFBFBD>ٶ<EFBFBD><D9B6>岻<EFBFBD><E5B2BB><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD>
|
|||
|
|
{
|
|||
|
|
UART_1,
|
|||
|
|
UART_2,
|
|||
|
|
UART_3,
|
|||
|
|
UART_4,
|
|||
|
|
UART_5,
|
|||
|
|
UART_6,
|
|||
|
|
UART_7,
|
|||
|
|
UART_8,
|
|||
|
|
}uart_index_enum;
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
extern const uint32 uart_index[];
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
void uart_write_byte (uart_index_enum uart_n, const uint8 dat);
|
|||
|
|
void uart_write_buffer (uart_index_enum uart_n, const uint8 *buff, uint32 len);
|
|||
|
|
void uart_write_string (uart_index_enum uart_n, const char *str);
|
|||
|
|
|
|||
|
|
uint8 uart_read_byte (uart_index_enum uartn);
|
|||
|
|
uint8 uart_query_byte (uart_index_enum uartn, uint8 *dat);
|
|||
|
|
|
|||
|
|
void uart_tx_interrupt (uart_index_enum uart_n, uint8 status);
|
|||
|
|
void uart_rx_interrupt (uart_index_enum uart_n, uint8 status);
|
|||
|
|
|
|||
|
|
void uart_init (uart_index_enum uart_n, uint32 baud, uart_pin_enum tx_pin, uart_pin_enum rx_pin);
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
#endif
|