STM32串口中断笔记

串口中断

  • 使用__HAL_UART_ENABLE_IT(&huart3, UART_IT_RXNE);开启中断,中断处理函数HAL_UART_IRQHandler会自动更新开启中断,回显代码例程如下:

    __HAL_UART_ENABLE_IT(&huart3, UART_IT_RXNE);
    
    /**
      * @brief This function handles USART3 global interrupt.
      */
    void USART3_IRQHandler(void)
    {
      /* USER CODE BEGIN USART3_IRQn 0 */
      if(__HAL_UART_GET_FLAG(&huart3, UART_FLAG_RXNE))
        {
            // Read the received byte
            uint8_t received_byte = (uint8_t)(huart3.Instance->DR & 0xFF);
            //HAL_UART_Receive(&huart3, reuart, 1, 10);
            
            // Echo the received data
            HAL_UART_Transmit(&huart3, &received_byte, 1, 10);  // Transmit the received byte with a timeout of 10ms
        }
    
      /* USER CODE END USART3_IRQn 0 */
      HAL_UART_IRQHandler(&huart3);
    
      /* USER CODE END USART3_IRQn 1 */
    }
    

    使用寄存器读取接收值和HAL_UART_Transmit都可以,推荐寄存器读取。

  • 使用HAL_UART_Receive_IT(&huart3, reuart, 1);开启中断,中断处理函数HAL_UART_IRQHandler不会自动更新开启中断,记得在中断中再次开启接收中断。

    uint8_t reuart[1]="\0"
    HAL_UART_Receive_IT(&huart3, reuart, 1);
    
    /**
      * @brief This function handles USART3 global interrupt.
      */
    void USART3_IRQHandler(void)
    {
      /* USER CODE BEGIN USART3_IRQn 0 */
    
      /* USER CODE END USART3_IRQn 0 */
      HAL_UART_IRQHandler(&huart3);
      /* USER CODE BEGIN USART3_IRQn 1 */
      HAL_UART_Transmit(&huart3, reuart, 1, 10);
      HAL_UART_Receive_IT(&huart3, reuart, 1);
    
      /* USER CODE END USART3_IRQn 1 */
    }
    

    或者在HAL_UART_RxCpltCallback中编写回调函数:

    void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
    {
    	 	 if(huart->Instance == USART3)
    	 {
    		 HAL_UART_Transmit(&huart1,reuart,1,100);
    	 }
    		
    }
    
    void USART3_IRQHandler(void)
    {
      /* USER CODE BEGIN USART3_IRQn 0 */
    
      /* USER CODE END USART3_IRQn 0 */
      HAL_UART_IRQHandler(&huart3);
      /* USER CODE BEGIN USART3_IRQn 1 */
      HAL_UART_Receive_IT(&huart3, reuart, 1);
    
      /* USER CODE END USART3_IRQn 1 */
    }
    

    大家可自行选择使用方法。

STM32F4中,串口中断服务函数的命名规则是根据不同的串口编号来确定的。根据引用\[1\]和引用\[2\]的描述,不同的串口有不同的中断服务函数命名。具体命名规则如下: - USART1的中断服务函数命名为USART1_IRQHandler() - USART2的中断服务函数命名为USART2_IRQHandler() - USART3的中断服务函数命名为USART3_IRQHandler() - UART4的中断服务函数命名为UART4_IRQHandler() - UART5的中断服务函数命名为UART5_IRQHandler() - USART6的中断服务函数命名为USART6_IRQHandler() - UART7的中断服务函数命名为UART7_IRQHandler() - UART8的中断服务函数命名为UART8_IRQHandler() 在这些中断服务函数中,可以根据需要编写相应的代码来处理接收到的数据。例如,根据引用\[3\]中的代码示例,可以在中断服务函数中使用USART_GetITStatus()函数来检查接收数据寄存器非空的状态,并使用USART_ReceiveData()函数来读取接收到的数据。然后,可以使用USART_SendData()函数将接收到的数据发送回去。 需要注意的是,以上命名规则是根据STM32F4的标准库来确定的,如果使用其他库或者自定义的命名规则,可能会有所不同。因此,在具体的项目中,需要根据所使用的库和配置来确定正确的中断服务函数命名。 #### 引用[.reference_title] - *1* *3* [串口接收中断配置过程---STM32F4--HAL](https://blog.csdn.net/qq_41683305/article/details/121380867)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [STM32 串口中断服务函数(学习笔记:2)](https://blog.csdn.net/Zao5544/article/details/119456680)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值