51单片机I2C通讯问题

2019-07-15 21:17发布

本帖最后由 kokuma 于 2013-12-17 11:39 编辑

        
        本人新手, 最近折腾单片机I2C通讯,做的还是最简单的51单片机操作24c02,不过在做的时候遇见了奇怪的问题:有的程序(大部分)无法对其进行操作,有的(目前就发现一个)却可以正常读写

        首先说出问题的程序,程序是照着郭天祥书上例8.3.1打的。打完后运行发现无法操作24c02,开始先排除硬件故障,检查开发板24c02的电气连接,不过开发板上走线看不清,无奈只好找当时附带的开发板配套程序(以下简称配套程序)做验证,结果找了好几个程序测试都不行。测试的时候WP悬空,开始怀疑硬件故障,遂买来新的24c02进行焊接。
附上原理图: 原理图 SCL和SDA通过俩单独的3k3电阻接在VCC上。
焊接好之后继续用开配套程序测试。测试的时候WP接的单片机GND,但是之前那几个不行的还不行,郭天祥那个程序放上去一样不能用,很郁闷,又找了一个新的配套程序测试,竟然能读写,大喜,至少证明硬件没故障,至此初步判断为程序问题。
         其实做测试的时候就一直怀疑程序问题,各种怀疑 也是无头苍蝇乱撞,因为单片机无法对器件进行操作,就考虑是不是时序问题,然后开始看波形 如图:
波形
这是那些不能操作24c02的程序的。探针挂在I2C总线上 单就这张图我也看不出来太多东西,至少start stop时序看着是对的,信号电平也没问题。高5低0,总线也是自己焊了俩3k3的电阻到VCC拉高。于是百般奇怪为啥无法读写。然后看了下24c02的手册,看到俩参数
AXFNV3~LI`6DI9YP3KBW47J.jpg
start保持时间和start建立时间,于是考虑是不是延时不够,
虽然5v版本(开发板上电压是5v的)要求的建立和保持时间都不到1个微秒,不过保险起见程序里的延时都是好几个微秒。所以还得折腾一下
      关于延时。出问题的程序用的是原作者自己写的delay函数。
函数体:
void delay()
{;;}
就俩空语句。用keil调试程序发现12M晶振下能延时4个微秒
PK$I_[E[LGCP8US{273_C_9.jpg
_RD7~@I~V2}HK{Q3~DOGN]H.jpg
_YWVZT5I8GECOCAV}6(]6HH.jpg

相比之下start建立和保持时间要求大于4.7微秒。能用的那个用的是_nop_(),
12m下一个nop延时1微秒。start的时候用了5个。。心想先给他换了看看。于是把delay换成nop。换完之后编译把hex考进去发现仍然不能用, 重新检查连接。没问题。重新考那个能用的程序,确实也能用。折腾半天不能用的还是不能用,
       那如果不是这里的问题,还能是哪儿的事儿,又开始看程序,这次注意到那个应答函数和读写字节的函数,多少都有区别。不过目前就只到这一步,还没来及去折腾这两块,心想不如发个帖子一起讨论,看有没有人遇到类似的情况,顺便把程序也发上来供解决问题之用。



97-2402存储1个数据.rar (22.7 KB, 下载次数: 18) 98-24c02存储多个数据.rar (21.89 KB, 下载次数: 19) iic_guotianxiang.rar (33.57 KB, 下载次数: 16)
这三个在我的开发板上无法正确操作24c02
100-24c02记忆开机次数.rar (24.45 KB, 下载次数: 34)
这一个是可以读写24c02的程序

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。