STM32 I2C OVR 错误

一、问题

STM32 I2C 用作从机时,开启如下中断并启用 callback 回调函数。
每一次复位后,从机都可以正常触发地址匹配中断ADDR,之后在该中断的回调函数中启用接收中断去收取数据时,却无法进入RXNE中断,而是触发了 OVR 错误中断。

void HAL_I2C_ListenCpltCallback(I2C_HandleTypeDef *hi2c)
void HAL_I2C_AddrCallback(I2C_HandleTypeDef *hi2c, uint8_t TransferDirection, uint16_t AddrMatchCode)
void HAL_I2C_SlaveTxCpltCallback(I2C_HandleTypeDef *hi2c)
void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c)
void HAL_I2C_ErrorCallback(I2C_HandleTypeDef *hi2c)

二、原因

通过简化代码,弃用库函数,改用寄存器操作发现可以正常进入接收中断,发现原来是系统主频太低导致。默认情况下,系统时钟为内部 HSI,仅 8MHz。使用 HSI48 后,便可正常使用库函数方式。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用I2C总线进行数据传输时,可以使用中断来提高系统的效率和可靠性。下面是使用STM32的HAL库进行I2C中断的步骤: 1. 配置I2C外设,包括I2C时钟频率、I2C地址、I2C工作模式等; 2. 配置I2C中断,包括I2C事件中断和I2C错误中断; 3. 在I2C事件中断服务函数中,根据不同的事件进行处理,例如数据传输完成、地址匹配、ACK错误等; 4. 在I2C错误中断服务函数中,处理I2C传输过程中可能出现的错误,例如总线错误、数据溢出等。 以下是一个简单的示例代码,演示了如何使用STM32的HAL库进行I2C中断: ```c // 配置I2C中断 HAL_I2C_Enable_IT(&hi2c1, I2C_IT_EVT | I2C_IT_ERR); // I2C事件中断服务函数 void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c) { if (hi2c->Instance == I2C1) { if (__HAL_I2C_GET_FLAG(&hi2c1, I2C_FLAG_ADDR)) { // 地址匹配事件 __HAL_I2C_CLEAR_ADDRFLAG(&hi2c1); // 处理数据传输 ... } else if (__HAL_I2C_GET_FLAG(&hi2c1, I2C_FLAG_TXE)) { // 数据传输完成事件 ... } else if (__HAL_I2C_GET_FLAG(&hi2c1, I2C_FLAG_RXNE)) { // 接收数据事件 ... } else if (__HAL_I2C_GET_FLAG(&hi2c1, I2C_FLAG_STOPF)) { // 停止位事件 __HAL_I2C_CLEAR_STOPFLAG(&hi2c1); } } } // I2C错误中断服务函数 void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c) { if (hi2c->Instance == I2C1) { if (__HAL_I2C_GET_FLAG(&hi2c1, I2C_FLAG_BERR)) { // 总线错误 __HAL_I2C_CLEAR_FLAG(&hi2c1, I2C_FLAG_BERR); } else if (__HAL_I2C_GET_FLAG(&hi2c1, I2C_FLAG_OVR)) { // 数据溢出 __HAL_I2C_CLEAR_FLAG(&hi2c1, I2C_FLAG_OVR); } else if (__HAL_I2C_GET_FLAG(&hi2c1, I2C_FLAG_AF)) { // ACK错误 __HAL_I2C_CLEAR_FLAG(&hi2c1, I2C_FLAG_AF); } } } ``` 在实际应用中,需要根据具体的需求进行配置和处理,以上代码仅供参考。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值