关于24C存储芯片及IIC的读写协议

上传人:大米 文档编号:464360434 上传时间:2023-02-04 格式:DOCX 页数:6 大小:39.41KB
返回 下载 相关 举报
关于24C存储芯片及IIC的读写协议_第1页
第1页 / 共6页
关于24C存储芯片及IIC的读写协议_第2页
第2页 / 共6页
关于24C存储芯片及IIC的读写协议_第3页
第3页 / 共6页
关于24C存储芯片及IIC的读写协议_第4页
第4页 / 共6页
关于24C存储芯片及IIC的读写协议_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《关于24C存储芯片及IIC的读写协议》由会员分享,可在线阅读,更多相关《关于24C存储芯片及IIC的读写协议(6页珍藏版)》请在金锄头文库上搜索。

1、关于24C存储芯片及IIC的读写协议所看过的对24系列I2C读写时序描述最准确最容易理解的资料,尤其是关于主从器件的应答描述和页写描述,看完后明白了很多。关于页写的描述,网络上绝大部分范程都没提到页写时的数据地址必须是每页的首地址才能准确写入,而且如果写入超过一页的数据会循环覆盖当前页的数据。 关于IIC总线 I2C总线:i2c总线是 Philips 公司首先推出的一种两线制串行传输总线。它由一根数据线和一根 时钟线组成。i2c总线的数据传输过程如图3所示,基本过程为: 1、主机发出开始信号。 2、主机接着送出1字节的从机地址信息,其中最低位为读写控制码,高7位为从机器件地址代码。 3、从机发

2、出认可信号。 4、主机开始发送信息,每发完一字节后,从机发出认可信号给主机。 5、主机发出停止信号。 I2C总线上各信号的具体说明: 开始信号:在时钟线为高电平其间,数据线由高变低,将产生一个开始信号。 停止信号:在时钟线为高电平其间,数据线由低变高,将产生一个停止信号。 应答信号:既认可信号,主机写从机时每写完一字节,如果正确从机将在下一个时钟周期将数据线拉低,以告诉主机操作有效。在主机读从机时正确读完一字节后,主机在下一个时钟周期同样也要将数据线拉低,发出认可信号,告诉从机所发数据已经收妥。 注意:在I2C通信过程中,所有的数据改变都必须在时钟线SCL为低电平时改变,在时钟线SCL为高电平

3、时必须保 持数据SDA信号的稳定,任何在时钟线为高电平时数据线上的电平改变都被认为是起始或停止信号。 作为一种非易失性存储器,24系列EEPROM使用的很普遍,一般作为数据量不太大的数据存储器。下面总结一下其应用的一些要点。从命名上看,24CXX中XX的单位是kbit,如24C08,其存储容量为8k bit,即1k Byte1024 Byte。 一、工作条件 1工作电压(VCC) 24CXX: 4.5V5.5V 24CXXW: 2.5V5.5V 24CXXR: 1.8V5.5V 2 输入电平定义(VIH,VIL) VIH:0.7VCCVCC+1 VIL:-0.45V0.3VCC 二、硬件连接

4、1上拉电阻RP的取值 由于I2C总线电容要满足小于400pf的条件。从以下波形可以看出,上拉电阻越大,总线的电容越小,可以实现的数据传输率就越大,可达400khz。 2写保护脚 芯片写保护脚是高电平有效,即WP接高电平时禁止写入 3地址脚 24C01/24C02 三个地址脚都有效,24C04只有E2,E1有效,24C08只有E2有效,24C16三个地址脚都无效,如下图所示,所谓地址脚无效是指不需要接入电路中(NC ,not connected),其对应的地址位要用来表示要操作的字节的高位地址。 24C32/24C64三个地址脚都有效; 24C128/24C256/24C512的地址脚E1和E0

5、有效,其余为NC; 24C1024的地址脚E1有效,其余为NC。 三、寻址方式 1器件地址 当总线上连接多个I2C器件时,需要对器件进行寻址。器件地址如下表所示,其中E2,E1,E0是指三个引脚的状态,取决于是接地还是接高电平,R/W为1则为读操作,为0则为写操作。A8,A9,A10,A16指的是所要操作的字节地址的高位,后面会提到。 芯片 bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 24C01/02/2 1 1 0 1 0 E2 E1 E0 R/W 24C04 1 0 1 0 E2 E1 A8 R/W 24C08 1 0 1 0 E2 A9 A8 R/W

6、24C16 1 0 1 0 A10 A9 A8 R/W 24C32/64 1 0 1 0 E2 E1 E0 R/W 24C128/256/512 1 0 1 0 0 E1 E0 R/W 24C1024 1 0 1 0 0 E1 A16 R/W 2.字节地址 在对芯片内的某一字节或一连续地址进行读写操作时,需要制定其地址或首字节的地址,不同芯片地址有不同的表示方式,如下表所示,其中有些芯片的地址位的高位存储在器件地址中。 芯片 地址位数 地址范围 24C01 bit7-bit0 0x00-0x7F 24C02 bit7-bit0 0x00-0xFF 24C04 A8,bit7-bit0 0x00

7、-0x1FF 24C08 A9,A8,bit7-bit0 0x00-0x3FF 24C16 A10,A9,A8,bit7-bit0 0x00-0x7FF 24C32 bit15-bit8,bit7-bit0 0x00-0xFFF 24C64 bit15-bit8,bit7-bit0 0x00-0x1FFF 24C128 bit7-bit0 0x00-0x3FFF 24C256 bit7-bit0 0x00-0x7FFF 24C512 bit7-bit0 0x00-0xFFFF 24C1024 A16,bit15-bit8,bit7-bit0 0x00-0x1FFFF 四、读写时序 EEPROM

8、一般在电路中做从器件,以下的发送和接收都是针对主器件说明的,开始和结束条件也是由主器件发出。 1、单字节写操作 START发送器件地址ack发送字节地址ack发送数据ack STOP 2、按“页”写操作,“页”是指高位地址一样一组数据,对于24C01/02/04/08/16,一页数据为16字节,一页指高四位地址一样的一组数据。对于24C32/24C64,一页数据为32字节,一页指高11位地址一样的一组数据。 START发送器件地址ack发送页首地址ack发送数据ack. 发送数据ack STOP 3、随机单字节读操作 START发送器件地址ack发送字节地址ackSTART发送器件地址ack接

9、收数据noackSTOP 4、当前单字节读操作,“当前”指的是前面进行过读操作,但是没有STOP,芯片内部“指针”指的字节即为“当前”字节。 START发送器件地址ack接收数据noackSTOP 5、随机连续字节读操作 START 发送器件地址ack发送字节首地址ackSTART发送器件地址 ack接收数据ack接收数据ack.接收数据(最后字节) noackSTOP 6、当前连续字节读操作 START发送器件地址ack接收数据ack接收数据 ack.接收数据(最后字节)noackSTOP 关于页写的道理。 AT24Cxx系列的EEPROM为了提高写效率,提供了页写功能,内部有个一页大小的写

10、缓冲RAM,地址范围当然就是从00到一页大小,发生写操作时,开始送入的地址对应的页被选中,并将其内容映像到缓冲RAM,数据从低端地址对应的缓冲RAM地址开始修改,超过这个地址范围就回到00,写完后,就会把开始确定的EEPROM页擦除,再把一整页RAM数据写入。所有写数据都发生在开始写地址时确定的页上。 如页容量为128,一页都是从00开始按128字节分成一个个的页,0页就是07F,1页就是80FF,类推,边界就是128字节的整数倍地址。页 RAM的地址范围为7位007F,写入时高端地址就是页号。发生写操作,开始送入的地址对应的页被锁存,后续不论写多少,都在这个页中,只是一个页内的地址进行加一,超过就归零开始。从F0开始写32个字节,那么开始送入的地址为F0,就会锁定在1号页上,底端7位页内部地址开始从70H开始写,到达7F时回到00再到10H,也就是写在了F0FF,808F。也就是,从01开始写也只能到7F,再往80写就跑到00上去了,这就是写操作的翻卷,datasheet上都有说明。就是从边界前写两个字节也要分两次写。页是绝对的,按整页大小排列,不是从开始写入的地址开始算。 读没有页的问题,可以从任意地址开始读取任意大小数据,只是超过整个存储器容量时地址才回卷。但一次性访问的数据长度也不要太大。所以分页的存储器要做好存储器管理,尽量同时读写的数据放在一个页上。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号