概述
本章主要配置printf進行打印。 查閱手冊可以得知,PA9、PA10為串口0的輸出和輸入口。需要GD樣片的可以加群申請:615061293。

樣品申請
https://www.wjx.top/vm/wFGhGPF.aspx#
硬件準備
這里準備了1塊開發(fā)板進行驗證,分別是GD32303C_START開發(fā)板。

keil配置
microlib 進行了高度優(yōu)化以使代碼變得很小。 它的功能比缺省 C 庫少,并且根本不具備某些 ISO C 特性。 某些庫函數(shù)的運行速度也比較慢,如果要使用printf(),必須開啟。

串口初始化
對串口進行配置。 使用串口時候,需要對GPIO進行復(fù)用這里把串口的 Tx 引腳配置為復(fù)用推挽輸出,Rx 引腳為浮空輸入。 設(shè)置USART0 通信參數(shù)為:波特率 115200,字長為 8,1 個停止位,沒有校驗位,收發(fā)一體工作模式,然后調(diào)用 USART 初始化函數(shù)完成配置。
/* 使能GPI0A,用PA9、PA10為串口 */
rcu_periph_clock_enable(RCU_GPIOA);
/*使能串口0的時鐘 */
rcu_periph_clock_enable(RCU_USART0);
/*配置USARTx_Tx(PA9)為復(fù)用推挽輸出*/
gpio_init(GPIOA, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_9);
/*配置USARTx_RxPA9)為浮空輸入 */
gpio_init(GPIOA, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, GPIO_PIN_10);
/* USART 配置 */
usart_deinit(USART0);//重置串口0
usart_baudrate_set(USART0, 115200U);//設(shè)置串口0的波特率為115200
usart_word_length_set(USART0, USART_WL_8BIT); // 幀數(shù)據(jù)字長
usart_stop_bit_set(USART0, USART_STB_1BIT); // 停止位1位
usart_parity_config(USART0, USART_PM_NONE); // 無奇偶校驗位
usart_receive_config(USART0, USART_RECEIVE_ENABLE);//使能接收器
usart_transmit_config(USART0, USART_TRANSMIT_ENABLE);//使能發(fā)送器
usart_enable(USART0);//使能USART
串口重定向
/* retarget the C library printf function to the USART */
int fputc(int ch, FILE *f)
{
usart_data_transmit(USART0, (uint8_t)ch);
while(RESET == usart_flag_get(USART0, USART_FLAG_TBE));
return ch;
}
串口重定向后就可以使用printf進行打印。
usart_data_transmit()發(fā)送
usart_data_transmit()是USART發(fā)送數(shù)據(jù)函數(shù)。 定義發(fā)送函數(shù)。
void uart_data_transmit(uint8_t arr[], uint32_t length)
{
uint32_t i;
for(i=0; iusart_data_transmit(USART0, arr[i]);
while (usart_flag_get(USART0, USART_FLAG_TBE)== RESET);
}
}
在主程序中添加代碼,打印HELLO!
while (1)
{
uint8_t str[] = "HELLO!\\r\\n";
uint32_t len = sizeof(str) / sizeof(*str);
uart_data_transmit(str,len-1);
delay_1ms(1000);
}
測試結(jié)果

中斷發(fā)送
若要使用串口的中斷函數(shù)USART0_IRQHandler(),需要先開啟串口中斷。

對于中斷發(fā)送,需要usart_interrupt_enable()開啟發(fā)送緩沖區(qū)空中斷。 搶占優(yōu)先級,數(shù)字越小,優(yōu)先級越高。 若搶占優(yōu)先級相同,判斷子優(yōu)先級,同樣,數(shù)字越小,優(yōu)先級越高。
/*開啟USART0中斷 */
nvic_irq_enable(USART0_IRQn, 0, 0);
/* 使能串口發(fā)送中斷 */
usart_interrupt_enable(USART0, USART_INT_TBE);
delay_1ms(1000); //開啟后會進入中斷進行發(fā)送,故需要進行一個延遲
定義發(fā)送變量。
#define ARRAYNUM(arr_nanme) (uint32_t)(sizeof(arr_nanme) / sizeof(*(arr_nanme)))
#define TRANSMIT_SIZE (ARRAYNUM(txbuffer) - 1)
uint8_t txbuffer[] = "\\n\\rUSART interrupt test\\n\\r";//發(fā)送的數(shù)據(jù)
uint8_t tx_size = TRANSMIT_SIZE;//需要發(fā)送數(shù)據(jù)長度
__IO uint8_t txcount = 0; //發(fā)送數(shù)據(jù)長度
串口中斷定義。
void USART0_IRQHandler(void)
{
if(RESET != usart_interrupt_flag_get(USART0, USART_INT_FLAG_TBE))//發(fā)送
{
/* transmit data */
usart_data_transmit(USART0, txbuffer[txcount++]);//發(fā)送一個八位數(shù)據(jù)
if(txcount == tx_size)//發(fā)送完畢
{
usart_interrupt_disable(USART0, USART_INT_TBE);//關(guān)閉發(fā)送中斷
}
}
}
測試結(jié)果

中斷接收
若要使用串口的中斷函數(shù)USART0_IRQHandler(),需要先開啟串口中斷。

對于中斷接收,需要usart_interrupt_enable()開啟接收中斷。 搶占優(yōu)先級,數(shù)字越小,優(yōu)先級越高。 若搶占優(yōu)先級相同,判斷子優(yōu)先級,同樣,數(shù)字越小,優(yōu)先級越高。
/*開啟USART0中斷 */
nvic_irq_enable(USART0_IRQn, 0, 0);
/* 使能串口發(fā)送中斷 */
usart_interrupt_enable(USART0, USART_INT_TBE);
delay_1ms(1000); //開啟后會進入中斷進行發(fā)送,故需要進行一個延遲
while(RESET == usart_flag_get(USART0, USART_FLAG_TC));//USART_FLAG_TC發(fā)送完成中斷
/* 使能串口接收中斷*/
usart_interrupt_enable(USART0, USART_INT_RBNE);
/* 等待接收完畢 */
while(rxcount < rx_size);
if(rxcount == rx_size)
printf("\\n\\r接收完畢,接收數(shù)據(jù)是:");
uart_data_transmit(rxbuffer,rx_size);//發(fā)送接收數(shù)據(jù)
printf("\\n\\r");
定義發(fā)送變量。
uint8_t rxbuffer[10];//接收數(shù)組
uint8_t rx_size = 10;//需要接收長度
__IO uint16_t rxcount = 0; //實際接收長度
串口中斷定義。
/*!
\\brief this function handles USART RBNE interrupt request and TBE interrupt request
\\param[in] none
\\param[out] none
\\retval none
*/
void USART0_IRQHandler(void)
{
if(RESET != usart_interrupt_flag_get(USART0, USART_INT_FLAG_RBNE)){
/* receive data */
rxbuffer[rxcount++] = usart_data_receive(USART0);
if(rxcount == rx_size){
usart_interrupt_disable(USART0, USART_INT_RBNE);
}
}
if(RESET != usart_interrupt_flag_get(USART0, USART_INT_FLAG_TBE))//發(fā)送
{
/* transmit data */
usart_data_transmit(USART0, txbuffer[txcount++]);//發(fā)送一個八位數(shù)據(jù)
if(txcount == tx_size)//發(fā)送完畢
{
usart_interrupt_disable(USART0, USART_INT_TBE);//關(guān)閉發(fā)送中斷
}
}
}
測試結(jié)果

審核編輯 黃昊宇
-
固件庫
+關(guān)注
關(guān)注
2文章
98瀏覽量
15526 -
gd32f303
+關(guān)注
關(guān)注
4文章
38瀏覽量
4139
發(fā)布評論請先 登錄
USART1、USART2、UART3的串口使用
MCU無法檢測到W5500是怎么回事?
backtrace命令無法使用?為什么?
GD32的串口DMA收發(fā)數(shù)據(jù)失敗怎么解決?
高新興瑞聯(lián)推出新款LTE Cat.1高性能OBD產(chǎn)品GD303
STM32/GD32開發(fā)板基本串口RS232\\RS485通信及CAN接口 usbhid升級 U盤升級 sd卡升級升級學(xué)習方案開發(fā)板
GD-LINK無法在KEIL上調(diào)試怎么解決?
GD32F30x和GD32F403硬件開發(fā)指南
AN136 基于GD32F30x系列的IEC60730 ClassB庫移植指南
基于GD32F3x0系列的IEC60730 ClassB庫移植指南

GD32F303固件庫開發(fā)(8)----USART收發(fā)配置
評論