stm32h7关串口中断怎么弄_STM32H7 串口 空闲中断 任意长接收 Hal库 IDLE

今天主要记录一下STM32H7系列串口的使用,正点原子、野火等各大家都有教程,当然用起来也没有问题。

解决方法后边有红色大字提醒,直接看后边就可以,如果你没有时间想去了解HAL库的接收思想。

ST推的HAL库,在整个接收过程中,是没有用到串口的接收空闲中断,它的处理有三种,分别是轮询,接收完成中断(每一个字节一次),DMA接收。

整个Hal库把接收和发送过程都封装好了,就用最简单的轮询方式看,先看库函数代码:

/**

* @brief Receive an amount of data in blocking mode.

* @note When FIFO mode is enabled, the RXFNE flag is set as long as the RXFIFO

* is not empty. Read operations from the RDR register are performed when

* RXFNE flag is set. From hardware perspective, RXFNE flag and

* RXNE are mapped on the same bit-field.

* @param huart UART handle.

* @param pData Pointer to data buffer.

* @param Size Amount of data to be received.

* @param Timeout Timeout duration.

* @retval HAL status

*/

HAL_StatusTypeDef HAL_UART_Receive(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout)

{

uint8_t *pdata8bits;

uint16_t *pdata16bits;

uint16_t uhMask;

uint32_t tickstart;

/* Check that a Rx process is not already ongoing */

if (huart->RxState == HAL_UART_STATE_READY)

{

if ((pData == NULL) || (Size == 0U))

{

return HAL_ERROR;

}

/* Process Locked */

__HAL_LOCK(huart);

huart->ErrorCode = HAL_UART_ERROR_NONE;

huart->RxState = HAL_UART_STATE_BUSY_RX;

/* Init tickstart for timeout managment*/

tickstart = HAL_GetTick();

huart->RxXferSize = Size;

huart->RxXferCount = Size;

/* Computation of UART mask to apply to RDR register */

UART_MASK_COMPUTATION(huart);

uhMask = huart->Mask;

/* In case of 9bits/No Parity transfer, pRxData needs to be handled as a uint16_t pointer */

if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE))

{

pdata8bits = NULL;

pdata16bits = (uint16_t *) pData;

}

else

{

pdata8bits = pData;

pdata16bits = NULL;

}

/* as long as data have to be received */

while (huart->RxXferCount > 0U)

{

if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK)

{

return HAL_TIMEOUT;

}

if (pdata8bits == NULL)

{

*pdata16bits = (uint16_t)(huart->Instance->RDR & uhMask);

pdata16bits++;

}

else

{

*pdata8bits = (uint8_t)(huart->Instance->RDR & (uint8_t)uhMask);

pdata8bits++;

}

huart->RxXferCount--;

}

/* At end of Rx process, restore huart->RxState to Ready */

huart->RxState = HAL_UART_STATE_READY;

/* Process Unlocked */

__HAL_UNLOCK(huart

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在STM32HAL库中,串口中断接收不定度的数据可以通过以下方法实现。 首先,我们可以使用HAL库中的`HAL_UART_Receive_IT`函数来启动串口接收中断,并设置接收缓冲区和接收度。例如,可以使用以下代码初始化串口接收: ```c uint8_t RxBuffer[100]; // 接收缓冲区 uint16_t RxSize; // 接收度 // 启动串口接收中断 HAL_UART_Receive_IT(&huart1, RxBuffer, 1); ``` 接下来,在串口接收中断处理函数`USART1_IRQHandler`中,可以通过获取接收数据的度,并根据需求进行处理。例如,可以使用以下代码获取接收度和处理接收数据: ```c void USART1_IRQHandler(void) { // 判断接收中断标志是否置位 if (__HAL_UART_GET_FLAG(&huart1, UART_FLAG_RXNE) != RESET) { // 清除接收中断标志 __HAL_UART_CLEAR_FLAG(&huart1, UART_FLAG_RXNE); // 接收数据 RxSize++; HAL_UART_Receive_IT(&huart1, &RxBuffer[RxSize], 1); // 处理接收数据 if (RxSize >= 10) { // 处理接收到的完整数据 // ... // 重置接收度和缓冲区 RxSize = 0; memset(RxBuffer, 0, sizeof(RxBuffer)); } } } ``` 在上述代码中,每次接收到一个字节的数据后,会增加接收度`RxSize`的值,并继续启动下一次接收中断。当接收度达到我们需要的度(例如10个字节)时,可以进行相应的处理逻辑,并重置接收度和缓冲区,以准备接收下一组数据。 通过以上方法,我们可以实现串口中断接收不定度的数据。根据不同的需求,可以灵活调整接收度和处理逻辑来适应具体的应用场景。 ### 回答2: STM32HAL库是STMicroelectronics推出的一套针对STM32系列微控制器的硬件抽象层库。在使用STM32HAL库时,我们可以通过使用串口中断来实现串口的不定接收。 在串口中断接收不定度的数据时,我们首先需要初始化串口以及中断设置。通过配置串口的波特率、数据位、停止位、校验位等参数,可以保证串口的正常工作。同时,我们还需要配置NVIC(Nested Vectored Interrupt Controller)中断控制器,使得串口接收中断能够正确触发。 接下来,在串口接收中断服务函数中,我们可以通过检查USART的接收缓冲区是否非空来确定是否有数据接收。如果接收缓冲区非空,则可以读取接收到的数据,并进行相应的处理。在不定接收的情况下,我们可以使用一个循环来不断读取数据,并根据我们自己的协议或规则来判断何时停止接收。 通常情况下,我们可以定义一个接收缓冲区数组,用于存储接收到的数据。在每次循环中,我们可以将接收到的数据存储到接收缓冲区中,并根据数据的特征来判断何时停止接收,例如可以设置一个特定的结束标志。 一旦接收结束,我们就可以进行后续的数据处理,例如解析数据、执行相操作等。需要注意的是,由于不定度数据的特性,在数据处理时应该对数据的有效性进行检查,避免错误操作或潜在的安全问题。 总的来说,通过使用STM32HAL库串口中断机制,我们可以实现串口的不定接收。通过正确配置串口中断设置,合理处理接收中断服务函数中的数据读取和处理逻辑,我们可以很方便地实现与外部设备的可靠通信。 ### 回答3: STM32HAL库中,通过使用串口中断可以实现不定度的串口接收。具体步骤如下: 1. 配置串口接收中断使能:通过调用`HAL_UART_Receive_IT()`函数,使能串口中断接收功能。该函数会启动中断接收,并将接收到的数据存储到缓冲区中。 2. 在中断处理函数中读取数据:当接收到数据后,会触发串口接收中断,此时会自动进入中断处理函数。在该中断处理函数中,可以调用`HAL_UART_Receive_IT()`函数来读取接收到的数据。 3. 判断数据接收完成:在中断处理函数中,可以通过判断接收到的数据度来确定数据是否接收完成。一般可以通过判断接收到的数据是否满足某一特定的结束标志。 4. 数据处理:当数据接收完成后,可以对接收到的数据进行相应的处理,比如解析数据,执行相应的操作等。 需要注意的是,在使用串口中断接收不定度数据时,需要事先确定好数据的传输格式和度,以便正确地进行接收和处理。同时,还需要配置好接收缓冲区的度,以确保能够容纳接收到的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值