stm32 I2C问题 I2C_CheckEvent()

STM32的IIC接口写的比较复杂,稍不注意,很多地方都会搞错,如果是用GPIO模拟的IIC,问题应该不大,无非应答不不应答的问题。

但是既然STM32自带IIC,并且有接口函数,干嘛不用呢

问题1:

I2C_CheckEvent() 检查时停在此处:

  /* Test on EV5 and clear it */

  while(!I2C_CheckEvent(I2C1, I2C_EVENT_MASTER_MODE_SELECT));

 

问题2:

第一次读写正确后再运行程序停在此处:

  /* Test on EV6 and clear it */

  while(!I2C_CheckEvent(I2C1, I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED));

 

其他问题:

这基本上就是该应答时没有应答造成

 

解决方法:

针对问题1,多数是因为IIC接口没有配置好,RCC设置中只设置了如下

  /* I2C1 Periph clock enable */

  RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1, ENABLE);  

却没有设置:

/* GPIOB Periph clock enable */

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);

以上两者都是必须的


针对问题2,一般是由于从设备速度不够快造成的

一般在IIC各个读写操作中加入一定的延时即可:

   I2C_8601_ByteWrite(0x02,0x01);

    afxCounterMs=1;

    while(afxCounterMs);     

    I2C_8601_ByteWrite(0x03,0x02);

    afxCounterMs=1;

    while(afxCounterMs);  


### STM32 I2C 中 `I2C_CheckEvent` 和 `I2C_GetFlagStatus` 的用法与区别 #### 函数定义与功能描述 在 STM32 的标准外设库中,`I2C_CheckEvent` 和 `I2C_GetFlagStatus` 是两个用于处理 I2C 通信状态的函数。 - **`I2C_CheckEvent`**: 此函数通过组合多个标志位的状态来判断当前发生的事件是否匹配指定条件。它主要用于简化复杂的多标志检测逻辑,使得开发者可以更方便地验证特定的 I2C 事件是否发生[^1]。 ```c ErrorStatus I2C_CheckEvent(I2C_TypeDef* I2Cx, uint32_t I2C_EVENT); ``` - **`I2C_GetFlagStatus`**: 该函数专门用来读取某个具体的硬件标志位的状态(设置或清除)。这允许开发人员单独检查某一个标志位的情况,而不涉及其他标志位的综合分析[^2]。 ```c FlagStatus I2C_GetFlagStatus(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG); ``` #### 使用场景对比 当需要确认一系列复杂条件下触发的具体事件时,通常会优先考虑使用 `I2C_CheckEvent`,因为它已经封装好了常见的 I2C 事件模式识别逻辑。而如果只是单纯关心某一具体标志位的变化情况,则更适合调用更为底层的 `I2C_GetFlagStatus` 来获取精确的信息。 例如,在主设备发送地址之后等待从机响应的过程中,可以通过如下方式分别利用这两个API实现相同目的: 对于 `I2C_CheckEvent` 方法: ```c while (I2C_CheckEvent(I2Cx, I2C_EV_MASTER_MODE_SELECT) != SUCCESS); // 等待直到进入主机模式选择阶段成功完成为止 ``` 而对于 `I2C_GetFlagStatus` 则需手动组合不同flags来进行同样的判定操作: ```c while (!(I2C_GetFlagStatus(I2Cx, I2C_FLAG_SB)) || !(I2C_GetFlagStatus(I2Cx, I2C_FLAG_ADDR))); // 同样等到SB(set bus)以及ADDR(address sent/received)都置位才继续执行下一步动作 ``` 上述例子展示了如何基于各自特性选用合适的工具去达成目标效果的同时也体现了两者的差异所在——前者更加高层抽象化易于理解应用;后者则提供了更大的灵活性供定制需求下的深入控制[^3]. #### 总结 综上所述,虽然两者最终都可以达到监控并反应I2C总线活动的目的,但是它们侧重点各有侧重:一个是针对预定义好的典型事务流程提供便捷接口(`I2C_CheckEvent`);另一个则是给予程序员直接访问内部寄存器的能力以便于实施个性化策略(`I2C_GetFlagStatus`)。 ```python # Python 示例仅作结构展示用途,实际为 C 语言环境讨论 def check_event(i2cx, event): return i2cx.check_event(event) def get_flag_status(i2cx, flag): return i2cx.get_flag_status(flag) ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值