stm32中断调用流程

USART1_IRQHandler(void)(中断服务函数)

-> HAL_UART_IRQHandler(UART_HandleTypeDef *huart)(中断处理函数)

-> UART_Receive_IT(UART_HandleTypeDef *huart) (接收函数)

-> HAL_UART_RxCpltCallback(huart);(中断回调函数)

  1. HAL_UART_IRQHandler(UART_HandleTypeDef *huart) 是UART中断处理函数,用于处理UART的中断事件。当UART模块触发中断时,该函数会被调用,并根据中断类型执行相应的操作。
  2. UART_Receive_IT(UART_HandleTypeDef *huart) 是接收函数,用于启动UART接收操作。它通过配置UART硬件相关寄存器和中断使能位,使得UART能够开始接收数据。一旦有数据到达,将触发接收中断,并调用中断回调函数。
  3. HAL_UART_RxCpltCallback(huart) 是中断回调函数,在UART接收完成后被自动调用。它是用户定义的函数,用于处理接收完成事件。在这个回调函数中,你可以对接收到的数据进行处理、解析或存储等操作,以及触发下一次接收操作。
  4. HAL_UART_Transmit() 函数用于通过UART发送数据。它接受以下参数:
    huart:指向UART_HandleTypeDef结构体的指针,表示要使用的UART外设。
    pData:指向要发送的数据缓冲区的指针。
    Size:要发送的数据的字节数。
    Timeout:发送超时时间,以毫秒为单位。
    该函数将数据从指定的缓冲区发送到UART外设。如果发送成功,则返回 HAL_OK,否则返回其他错误代码。在发送过程中,函数会根据指定的超时时间等待发送完成或超时。

由于stm32有很多外设,为降低功耗,每个外设都对应着一个时钟。在芯片刚刚上电时,这些时钟都是被关闭的。如果想要外设工作,必须把相应的时钟打开。

即当GPIO口复用USART进行通讯时,必须要先使能GPIO的时钟,然后再使能具体外设的时钟(USART的时钟)!!!

在STM32的串口中断服务函数中实现队列缓冲接收,可以按照以下步骤进行操作:

  1. 创建一个缓冲区队列,用于存储接收到的数据。这可以是一个循环队列或者使用其他合适的数据结构。
  2. 在串口中断服务函数中,读取接收到的数据,并将其放入缓冲区队列中。你可以使用适当的API函数来读取和写入数据。
  3. 在主程序中,从缓冲区队列中读取数据进行处理。可以使用轮询方式或者定时检查队列来获取数据。

下面是一个简单的示例代码,演示了如何在STM32串口中断服务函数中实现队列缓冲接收(以STM32Cube HAL库为例):

复制代码
#define BUFFER_SIZE 100

uint8_t rx_buffer[BUFFER_SIZE];
volatile uint16_t rx_buffer_head = 0;
volatile uint16_t rx_buffer_tail = 0;

/* UART Receive Complete Interrupt Handler */void USART1_IRQHandler(void)
{
if(__HAL_UART_GET_FLAG(&huart1, UART_FLAG_RXNE))
{
rx_buffer[rx_buffer_head] = huart1.Instance->DR;
rx_buffer_head = (rx_buffer_head + 1) % BUFFER_SIZE;
}
}

/* Read data from buffer */uint16_t readFromBuffer(uint8_t* data, uint16_t len)
{
uint16_t bytesRead = 0;
while (bytesRead < len)
{
if(rx_buffer_head != rx_buffer_tail)
{
data[bytesRead] = rx_buffer[rx_buffer_tail];
rx_buffer_tail = (rx_buffer_tail + 1) % BUFFER_SIZE;
bytesRead++;
}
else
{
break; // No more data in buffer
}
}
return bytesRead;
}

int main(void)
{
/* Initialize USART1 and enable interrupt */
while(1)
{
uint8_t receivedData[10];
uint16_t numBytes = readFromBuffer(receivedData, sizeof(receivedData));
// Process received data
// ...
}
}

在这个例子中,rx_buffer数组用于存储串口接收到的数据,rx_buffer_head和rx_buffer_tail是指向缓冲区头部和尾部的索引。USART1_IRQHandler函数是UART的接收中断服务函数,它将接收到的数据存储到缓冲区队列中。readFromBuffer函数用于从缓冲区队列中读取数据并返回读取的字节数。主程序中使用while循环来不断从缓冲区中读取数据进行处理。

请注意,这只是一个简单的示例代码,实际应用中可能需要进一步优化和添加错误处理机制来确保数据的完整性和正确性。

相关推荐
xuxg20052 小时前
4G 模组 AT 命令解析框架课程正式发布
stm32·嵌入式·at命令解析框架
CODECOLLECT3 小时前
京元 I62D Windows PDA 技术拆解:Windows 10 IoT 兼容 + 硬解码模块,如何降低工业软件迁移成本?
stm32·单片机·嵌入式硬件
BackCatK Chen4 小时前
STM32+FreeRTOS:嵌入式开发的黄金搭档,未来十年就靠它了!
stm32·单片机·嵌入式硬件·freertos·低功耗·rtdbs·工业控制
全栈游侠6 小时前
STM32F103XX 02-电源与备份寄存器
stm32·单片机·嵌入式硬件
Lsir10110_7 小时前
【Linux】中断 —— 操作系统的运行基石
linux·运维·嵌入式硬件
深圳市九鼎创展科技9 小时前
瑞芯微 RK3399 开发板 X3399 评测:高性能 ARM 平台的多面手
linux·arm开发·人工智能·单片机·嵌入式硬件·边缘计算
辰哥单片机设计9 小时前
STM32项目分享:车辆防盗报警系统
stm32·单片机·嵌入式硬件
風清掦10 小时前
【江科大STM32学习笔记-05】EXTI外部中断11
笔记·stm32·学习
小龙报10 小时前
【51单片机】从 0 到 1 玩转 51 蜂鸣器:分清有源无源,轻松驱动它奏响新年旋律
c语言·数据结构·c++·stm32·单片机·嵌入式硬件·51单片机
范纹杉想快点毕业10 小时前
嵌入式与单片机开发核心学习指南——从思维转变到第一性原理的深度实践
单片机·嵌入式硬件