STM32最小核心板使用HAL库实现UART接口通讯(中断方式)

正式环境里需要串联电阻,或设计过滤电路。核心板是STM32F103C8T6

这里使用了UART3的接口,具体使用MX创建项目就不放了,百度下都有

/*
    USART3 GPIO Configuration
    PB10     ------> USART3_TX
    PB11     ------> USART3_RX
*/

因为是串口通讯所以双机接线需要交叉

接口的关键代码配置如下:

cpp 复制代码
void MX_USART3_UART_Init(void)
{
  huart3.Instance = USART3;
  huart3.Init.BaudRate = 115200;
  huart3.Init.WordLength = UART_WORDLENGTH_8B;
  huart3.Init.StopBits = UART_STOPBITS_1;
  huart3.Init.Parity = UART_PARITY_NONE;
  huart3.Init.Mode = UART_MODE_TX_RX;
  huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  huart3.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart3) != HAL_OK)
  {
    Error_Handler();
  }
}

void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
{

  GPIO_InitTypeDef GPIO_InitStruct = {0};
  if(uartHandle->Instance==USART3)
  {
    /* USART3 clock enable */
    __HAL_RCC_USART3_CLK_ENABLE();

    __HAL_RCC_GPIOB_CLK_ENABLE();
    /**USART3 GPIO Configuration
    PB10     ------> USART3_TX
    PB11     ------> USART3_RX
    */
    GPIO_InitStruct.Pin = GPIO_PIN_10;
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
    HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);

    GPIO_InitStruct.Pin = GPIO_PIN_11;
    GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
    GPIO_InitStruct.Pull = GPIO_NOPULL;
    HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);

    /* USART3 interrupt Init */
    HAL_NVIC_SetPriority(USART3_IRQn, 0, 0);
    HAL_NVIC_EnableIRQ(USART3_IRQn);
  }
}

因为是中断方式收数据,所以需要自己实现个中断函数,系统会自己重载你实现的函数(名字要对)

cpp 复制代码
//全局变量
char aRxChr;	
char aRxBuffer[100];
uint32_t nRxLen;
//中断函数
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
	if(huart->Instance == USART3){
		if (nRxLen == 0){
			memset(aRxBuffer,0,100);
		}
        //判断结束标志位字符
		if (aRxChr != '#'){
				aRxBuffer[nRxLen] =aRxChr;
				nRxLen++;
		}else{
			  aRxBuffer[nRxLen] = 0;
				nRxLen = 0;
		}
        //打开中断
		HAL_UART_Receive_IT(&huart3,(uint8_t*)&aRxChr,1);
	}
}

需要接收不固定长度的数据,所以必须1个字节1个字节的收,然后组合成完整的。

最后给出Main主线程里的测试代码

cpp 复制代码
//上面其他的初始化就不放了,放关键的
MX_USART3_UART_Init();

nRxLen = 0;
uint8_t aTxBuffer[]="1234567890#";
//打开收中断
HAL_UART_Receive_IT(&huart3,(uint8_t*)&aRxChr,1);	
	
while (1) {
    //发送数据
    HAL_UART_Transmit(&huart3,(uint8_t*)&aTxBuffer,strlen(aTxBuffer),100);

    //这里可以处理aRxBuffer的内容,如果要搞的好点就再自己搞个锁来判断是否收到完整数据


    HAL_Delay(1000);
}
相关推荐
极客小张29 分钟前
基于STM32MP157与OpenCV的嵌入式Linux人脸识别系统开发设计流程
linux·stm32·单片机·opencv·物联网
OH五星上将1 小时前
OpenHarmony(鸿蒙南向开发)——小型系统内核(LiteOS-A)【扩展组件】上
linux·嵌入式硬件·harmonyos·openharmony·鸿蒙开发·liteos-a·鸿蒙内核
浅陌pa2 小时前
24:RTC实时时钟
c语言·stm32·单片机·嵌入式硬件
敲上瘾2 小时前
多态的使用和原理(c++详解)
开发语言·数据结构·c++·单片机·aigc·多态·模拟
小熊在忙fpga2 小时前
STM32如何修改外部晶振频率和主频
stm32·单片机·嵌入式硬件
我命由我123452 小时前
GPIO 理解(基本功能、模拟案例)
linux·运维·服务器·c语言·c++·嵌入式硬件·c#
学习日记hhh3 小时前
STM32G431RBT6(蓝桥杯)串口(发送)
stm32·单片机·嵌入式硬件
老李的森林3 小时前
嵌入式开发--STM32延时函数重构
stm32·单片机·嵌入式硬件·重构·延时
OH五星上将5 小时前
OpenHarmony(鸿蒙南向开发)——小型系统内核(LiteOS-A)【内核通信机制】上
linux·嵌入式硬件·harmonyos·openharmony·鸿蒙开发·liteos-a·鸿蒙内核
爱桥代码的程序媛5 小时前
鸿蒙OpenHarmony【轻量系统内核通信机制(互斥锁)】子系统开发
嵌入式硬件·harmonyos·鸿蒙·openharmony··鸿蒙开发·子系统开发