你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32 硬件I2C bug解决方案

[复制链接]
ajane 发布时间:2015-1-5 16:49
古人说的一句,方法总比问题多,真的一点儿也不假
( U4 f. C7 E" B/ H
8 S9 x5 N: C+ h% S4 S) `硬件有问题,怕啥,大神来支招,就算是先天性bug,一样搞定
# q( e/ E' [$ t8 t最近看到一个硬件I2C bug解决的方案,特来与大家分享
* `: b9 m% y0 S; q大神从芯片底层分析了为啥会有这样的bug,真大神也
7 d, X: r2 A& e0 Dhttp://racede.me/talk_about_stm32_i2c_peripheral.html- t2 f( n/ }, e3 s3 R; F
后面给出的解决方案如下:
$ {1 M+ m" f! _! E2 p( [3 u3 v+ [
发送时:
4 R- Y2 [4 H1 K- P/ d. f" h4 G7 g, w
开始,发送写地址,器件应答,清ADDR,一字节数据到写DR,硬件把DR数据写入到DSR,当DSR传输完毕时,DR也为空,BTF置位,这时我们再写一字节数据到DR,如此循环,最后一次BTF置位的时候发送P或者重起始(R)。这样操作,“硬件把DR数据写入到DSR”执行的时间是我们可以预料的,不存在上面提及的冲突问题。2 ]; j) J) J1 S2 p9 x

, S/ K0 R& Q. M; ?8 ]0 I" f接收时:
' |$ E3 A* k, M6 I
8 B& B7 X9 V( r. l2 m1、接收一个字节:按照ST给的方法。开始,发送读地址,器件应答,清ADDR前软件下拉SCL,写完NACK、STOP和DR后软件再释放SCL。RxNE时读DR。
9 B  G- u8 z( y% V: e9 P* ]. z, k. n' y1 k
2、接收两个字节:也是按照ST的方法。开始,发送读地址,器件应答,设置POS和ACK,下拉SCL,清ADDR,设置NACK,释放SCL。BTF时,软件拉低SCL,发送STOP,读DR,释放SCL,再读DR。
' [% R$ y; }" S6 Q8 a2 d! g# S
/ t0 L& u* z  {3、接收两个以上字节:开始,发送读地址,器件应答,直接清ADDR。BTF时,读DR一次。再BTF,再读DR一次,如此循环。倒数第二次BTF时设置NACK(注意DR和DSR各有一字节的数据),读DR一次。再等到最后一次BTF时,软件拉低SCL,发送STOP,读DR,释放SCL,再读DR。
具体的,还是靠大家自己去参悟啦
, ]9 G; R2 X7 r* e
收藏 2 评论14 发布时间:2015-1-5 16:49

举报

14个回答
巅峰残狼 回答时间:2015-1-5 16:56:27
这种帖子含金量蛮高的,支持多发这种帖子
ajane 回答时间:2015-1-5 17:04:42
巅峰残狼 发表于 2015-1-5 16:56
* N& X- W! H- H* `9 J" w这种帖子含金量蛮高的,支持多发这种帖子

4 b) x" N& r& F+ ~/ h4 J斑斑见笑了
qianfan 回答时间:2015-1-5 18:59:43
之前调试的时候,就是多个字节发送的时候太麻烦了,用他的硬件发送的时候,看见勘误手册上写着,当发送一个字节的时候应该怎么办,两个字节的时候应该怎么办,实在是太麻烦了,后来直接使用模拟算了。
! v# e, ~$ J' d% C7 d* f不考虑多主机的时候,模拟也是不错的选择。
ajane 回答时间:2015-1-5 19:02:27
QianFan 发表于 2015-1-5 18:595 k: M) o0 S; `
之前调试的时候,就是多个字节发送的时候太麻烦了,用他的硬件发送的时候,看见勘误手册上写着,当发送一个 ...

4 j6 U# `* X6 g: ~; C: z7 {- X; K, R确实啊,模拟的,可移植性很强。硬件I2C,想规避bug的话,确实很蛋疼,不知道ST怎么想的,哈哈
qianfan 回答时间:2015-1-5 19:04:45
ajane 发表于 2015-1-5 19:02  o# ~. d- e' u( R  ]. A5 F( t
确实啊,模拟的,可移植性很强。硬件I2C,想规避bug的话,确实很蛋疼,不知道ST怎么想的,哈哈 ...
+ k* W# i+ Z- h1 y* F! u
之前看过一个帖子,不知道是不是真的,说的是ST不愿意花钱买NXP的专利,于是自己做了这么一套。不知道是不是真的。9 }# q0 c% D! X( Z5 ]% P
如果不想买专利的话,像ATMEL那样换一个名字不就好了
ajane 回答时间:2015-1-5 19:06:03
QianFan 发表于 2015-1-5 19:04
! F0 E: t+ y0 I% V之前看过一个帖子,不知道是不是真的,说的是ST不愿意花钱买NXP的专利,于是自己做了这么一套。不知道是 ...

, P! ]6 p' X. X+ `% h坑。。。还好有大神支招,哈哈
qianfan 回答时间:2015-1-5 19:07:54
ajane 发表于 2015-1-5 19:06. N% U/ m. c6 J' Z& h! L
坑。。。还好有大神支招,哈哈
; ^1 b% F! v( o" J
另起一个名字,就叫什么ST-LINK,哈哈哈
ajane 回答时间:2015-1-5 19:18:08
QianFan 发表于 2015-1-5 19:07
" ^3 @1 C+ H  P! w& F- F另起一个名字,就叫什么ST-LINK,哈哈哈
7 ^; i, a* Q4 u; ?- C' j
全都是Link,也凌乱了,哈哈
stary666 回答时间:2015-7-17 10:08:22
顶一下,,,,,,,,,,
JackieLaura 回答时间:2015-7-17 10:49:21
不错的资料,去试试看了。。
stary666 回答时间:2015-7-17 14:01:05
st的i2c是很烂的,我就遇到问题了,用中断发送数据时,会多发1个0
zhlking2001 回答时间:2017-2-5 10:38:24
感谢分析分享!!!
zbber 回答时间:2017-2-5 22:22:22
之前调试的时候,就是多个字节发送的时候太麻烦了,用他的硬件发送的时候,看见勘误手册上写着,当发送一个
joelai 回答时间:2018-9-10 22:16:11
感謝分享

所属标签

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版