在STM32F103C8T6中使用HAL库函数的UART模块时注意事项

本文介绍了在使用STM32F103C8T6和HAL库进行UART通信时需要注意的问题。包括HAL_UART_MspInit()中禁止使用中断发送和接收函数,HAL_UART_RxCpltCallback()回调中避免发送乱码,HAL_UART_Transmit()参数限制,快速收发可能导致的卡死问题,以及中断处理函数中避免阻塞式收发等细节。
摘要由CSDN通过智能技术生成

开发板:普中A7板子
核心板:STM32F103C8T6
HAL库版本:STM32Cube_FW_F1_V1.8.0

注意事项:
1、在HAL_UART_MspInit()函数中不能使用HAL_UART_Receive_IT()或HAL_UART_Transmit_IT()函数,否则不会进入中断处理函数中,也就是说设置中断无效;
2、在HAL_UART_RxCpltCallback()回调函数中不能使用HAL_UART_Transmit_IT()进行发送数据,否则发送出去的就是乱码’?'这个符号;
3、在HAL_UART_Transmit(&UART_Struct,recv_buf,50,1000)这个函数中参数50会导致输出一部分字符后卡死;只能设置为HAL_UART_Transmit(&UART_Struct,recv_buf,1,1000)参数为1;
4、如果在HAL_UART_RxCpltCallback()函数中使用HAL_UART_Transmit()来发送数据,串口调试助手发送数据到单片机点快一点的话 就会卡死,而使用直接写寄存器发就不会卡死;在printf重定位中的fputc()函数中使用HAL_UART_Transmit()来发送数据,并在main()主函数中的while(1)死循环里面只用printf()函数打印数据就不会出现卡死的情况;
5、不能在USART1_IRQHandler()中断处理函数中使用HAL_UART_Receive()和HAL_UART_Transmit()函数,因为这两个是阻塞式的容易造成程序卡死

/****************************************************************************************
 * 函数功能:main主函数
 * 参    数:
 * 返 回 值:
 * 注意事项:
 ***************************************************************************************/
int main(void)
{
   
	unsigned char i, j = 0;
	HAL_Init();
	SystemClock_Config();
	
	UART_Init();
	Led_Init();
	
	printf("This is test function\r\n");

	while (1)
	{
   
		printf("Hello World %d\r\n", j++);
//		for(i=0; i<8; i++)
//		{
   
//			LED_ON(i);
//			HAL_Delay(500);
//			LED_OFF(i);	
//		}		
	}
}

/**
  * @brief  System Clock Configuration
  *         The system Clock is configured as follow : 
  *            System Clock source            = PLL (HSI)
  *            SYSCLK(Hz)                     = 72000000
  *            HCLK(Hz)                       = 72000000
  *            AHB Prescaler                  = 1
  *            APB1 Prescaler                 = 2
  *            APB2 Prescaler                 = 1
  *            PLLMUL                         = 9
  *            Flash Latency(WS)              = 2
  * @param  None
  * @retval None
  */
void SystemClock_Config(void)
{
   
	RCC_ClkInitTypeDef clkinitstruct = {
   0};
	RCC_OscInitTypeDef oscinitstruct 
以下是基于标准库的STM32F103C8T6串口1配置过程: 1. 首先,需要在CubeMX配置串口1的引脚和钟。将PA9配置为USART1_TX,将PA10配置为USART1_RX,并启用USART1钟。 2. 在代码包含以下头文件: ```c #include "stm32f1xx.h" #include "stm32f1xx_hal.h" ``` 3. 在main函数初始化串口1: ```c UART_HandleTypeDef huart1; void SystemClock_Config(void); static void MX_GPIO_Init(void); static void MX_USART1_UART_Init(void); int main(void) { HAL_Init(); SystemClock_Config(); MX_GPIO_Init(); MX_USART1_UART_Init(); while (1) { } } static void MX_USART1_UART_Init(void) { huart1.Instance = USART1; huart1.Init.BaudRate = 9600; huart1.Init.WordLength = UART_WORDLENGTH_8B; huart1.Init.StopBits = UART_STOPBITS_1; huart1.Init.Parity = UART_PARITY_NONE; huart1.Init.Mode = UART_MODE_TX_RX; huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE; huart1.Init.OverSampling = UART_OVERSAMPLING_16; if (HAL_UART_Init(&huart1) != HAL_OK) { Error_Handler(); } } ``` 在上述代码,我们初始化了UART_HandleTypeDef结构体的各个成员,包括波特率,数据位数,停止位数,校验位等。然后,我们调用HAL_UART_Init()函数初始化串口1。 4. 接下来,发送数据到串口1: ```c HAL_UART_Transmit(&huart1, (uint8_t*)"Hello, World!", 13, HAL_MAX_DELAY); ``` 在上述代码,我们使用HAL_UART_Transmit()函数向串口1发送数据。第一个参数是指向UART_HandleTypeDef结构体的指针,第二个参数是指向发送数据的指针,第三个参数是发送数据的长度,第四个参数是最长等待间。 5. 最后,接收数据: ```c uint8_t data[10]; HAL_UART_Receive(&huart1, data, 10, HAL_MAX_DELAY); ``` 在上述代码,我们使用HAL_UART_Receive()函数接收串口1的数据。第一个参数是指向UART_HandleTypeDef结构体的指针,第二个参数是指向存储接收数据的数组的指针,第三个参数是接收数据的长度,第四个参数是最长等待间。 以上就是基于标准库的STM32F103C8T6串口1配置过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值