本帖最后由 dirty123 于 2024-4-24 22:35 编辑
本篇讲述AT-START-F405开发板串口打印功能,其在我们平时调试开发中起到日志作用。
一.硬件原理了解
通过芯片手册与原理图,使用UART1, 接口为PA9--USART_TX,PA10--USART_RX。原理图分为USB转串口部分和MCU侧串口连接,如下
图1:USB转串口
图2:MCU侧串口连接
二.代码准备
1.在at32f402_405_board.c串口初始化代码如下:
void uart_print_init(uint32_t baudrate)
{
gpio_init_type gpio_init_struct;
#if defined (__GNUC__) && !defined (__clang__)
setvbuf(stdout, NULL, _IONBF, 0);
#endif
/* enable the uart and gpio clock */
crm_periph_clock_enable(PRINT_UART_CRM_CLK, TRUE);
crm_periph_clock_enable(PRINT_UART_TX_GPIO_CRM_CLK, TRUE);
gpio_default_para_init(&gpio_init_struct);
/* configure the uart tx pin */
gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
gpio_init_struct.gpio_mode = GPIO_MODE_MUX;
gpio_init_struct.gpio_pins = PRINT_UART_TX_PIN;
gpio_init_struct.gpio_pull = GPIO_PULL_NONE;
gpio_init(PRINT_UART_TX_GPIO, &gpio_init_struct);
gpio_pin_mux_config(PRINT_UART_TX_GPIO, PRINT_UART_TX_PIN_SOURCE, PRINT_UART_TX_PIN_MUX_NUM);
/* configure uart param */
usart_init(PRINT_UART, baudrate, USART_DATA_8BITS, USART_STOP_1_BIT);
usart_transmitter_enable(PRINT_UART, TRUE);
usart_enable(PRINT_UART, TRUE);
}
2.printf直接使用了ARM库映射,定义在keil安装路径下的stdio.h
图3:printf映射
3.main函数添加打印日志如下,主循环实现1s计数打印
int main(void)
{
system_clock_config();
at32_board_init();
uart_print_init(115200);
/* output a message on hyperterminal using printf function */
printf("usart printf example: retarget the c library printf function to the usart\r\n");
while(1)
{
printf("usart printf counter: %u\r\n",time_cnt++);
delay_sec(1);
}
}
三.编译烧录测试
编译烧录后重启运行日志如下,可以看到串口打印功能实现了。
图4:串口日志
|