OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4725|回复: 2

关于硬件IIC问题,时序问题

[复制链接]

16

主题

90

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
368
金钱
368
注册时间
2019-10-24
在线时间
153 小时
发表于 2022-5-5 16:18:28 | 显示全部楼层 |阅读模式
20金钱
本帖最后由 PYC1 于 2022-5-5 16:32 编辑

现用H743ZIT6配AT24C0512的硬件IIC时钟树和IIC1




按理说用库函数应该可以直接进行读写了,但结果不行
找过C0521的datasheet 高低电平时间分别为 Thigh=1.0us  Tlow=1.3us(电压3.3), 根据手册tSCLH = (SCLH+1) x tPRESC=(52+1)*100*1024*1024=0.5us 这个不够1us啊
有大佬做过CAT24C0512的硬件IIC吗,我之前用H743IIT6开发板配硬件IIC都直接可以用(AT24c02),
而且从手册来看不同的IC时序要求不一致,MX怎么能判断不同的IC生成不同的时序呢求指点


最佳答案

查看完整内容[请看2#楼]

虽然没清楚具体原理,记录一下调试过程eeprom是24c0512,用MX配置了时钟+IIC,其中IO必须配上拉电阻,生成代码后调试发现读的全是FF(网上查找原因是从机没回应或从机故障) 再找发现512写入时序是要发送16位的地址,但是MX生成的库函数为HAL_I2C_Master_Transmit无16位地址形参入口,于是用原子例程中的库函数 HAL_I2C_Mem_Write(&hi2c1,0xA0,0,I2C_MEMADD_SIZE_16BIT,&send[0],5,1000);如此这样24C0512即可正常读写。 不解之处还 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

16

主题

90

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
368
金钱
368
注册时间
2019-10-24
在线时间
153 小时
 楼主| 发表于 2022-5-5 16:18:29 | 显示全部楼层
虽然没清楚具体原理,记录一下调试过程eeprom是24c0512,用MX配置了时钟+IIC,其中IO必须配上拉电阻,生成代码后调试发现读的全是FF(网上查找原因是从机没回应或从机故障)
再找发现512写入时序是要发送16位的地址,但是MX生成的库函数为HAL_I2C_Master_Transmit无16位地址形参入口,于是用原子例程中的库函数
HAL_I2C_Mem_Write(&hi2c1,0xA0,0,I2C_MEMADD_SIZE_16BIT,&send[0],5,1000);如此这样24C0512即可正常读写。
不解之处还是甚多,举例记录
1.IIC通讯原理,时序,起始,停止,器件地址,一个周期(Tlow+Thign)是否满足IC要求(此为设备原理)
2.当MX配置生成代码有问题时,如何通过本质原理去查找问题,去啃库函数吗?
总结:感觉现在的状态还是纯纯的调试,遇到一些复杂的问题很难通过现象去看到本质,延申到类似LWIP,FREERTOS等都局限于应用的层面
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2022-5-5 23:58:59 | 显示全部楼层
建议用软件模拟
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-25 18:28

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表