收藏 分销(赏)

AT24C02串行E2PROM的工作原理与读写.doc

上传人:精*** 文档编号:1806178 上传时间:2024-05-09 格式:DOC 页数:10 大小:34.04KB
下载 相关 举报
AT24C02串行E2PROM的工作原理与读写.doc_第1页
第1页 / 共10页
AT24C02串行E2PROM的工作原理与读写.doc_第2页
第2页 / 共10页
AT24C02串行E2PROM的工作原理与读写.doc_第3页
第3页 / 共10页
AT24C02串行E2PROM的工作原理与读写.doc_第4页
第4页 / 共10页
AT24C02串行E2PROM的工作原理与读写.doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

1、.AT24C02串行E2PROM的工作原理与读写串行EEPROM中,较为典型的有ATMEL公司的AT24CXX系列和AT93CXX等系列产品。简称I2C总线式串行器件。串行器件不仅占用很少的资源和I/O线,而且体积大大缩小,同时具有工作电源宽、抗干扰能力强、功耗低、数据不易丧失和支持在线编程等特点。 I2C总线是一种用于IC器件之间连接的二线制总线。它通过SDA串行数据线及SCL串行时钟线)两根线在连到总线上的器件之间传送信息,并根据地址识别每个器件:不管是单片机、存储器、LCD驱动器还是键盘接口。1I2C总线的根本结构:采用I2C总线标准的单片机或IC器件,其内部不仅有I2C接口电路,而且将

2、内部各单元电路按功能划分为假设干相对独立的模块,通过软件寻址实现片选,减少了器件片选线的连接。CPU不仅能通过指令将某个功能单元电路挂靠或摘离总线,还可对该单元的工作状况进行检测,从而实现对硬件系统的既简单又灵活的扩展与控制。I2C总线接口电路结构如图1所示。 从图中可以看出:对于时钟及数据传送,串行数据I/O端SDA一般需要用外部上拉电阻将其电平拉高。2双向传输的接口特性:传统的单片机串行接口的发送和接收一般都分别用一条线,如MCS51系列的TXD和RXD,而I2C总线那么根据器件的功能通过软件程序使其可工作于发送或接收方式。当某个器件向总线上发送信息时,它就是发送器(也叫主器件),而当其从

3、总线上接收信息时,又成为接收器(也叫从器件)。主器件用于启动总线上传送数据并产生时钟以开放传送的器件,此时任何被寻址的器件均被认为是从器件。I2C总线的控制完全由挂接在总线上的主器件送出的地址和数据决定。总线上主和从(即发送和接收)的关系不是一成不变的,而是取决于此时数据传送的方向。SDA和SCL均为双向I/O线,通过上拉电阻接正电源。当总线空闲时,两根线都是高电平。连接总线的器件的输出级必须是集电极或漏极开路,以具有线“与功能。I2C总线的数据传送速率在标准工作方式下为100kbit/s,在快速方式下,最高传送速率可达400kbit/s。3I2C总线上的时钟信号:在I2C总线上传送信息时的时

4、钟同步信号是由挂接在SCL时钟线上的所有器件的逻辑“与完成的。SCL线上由高电平到低电平的跳变将影响到这些器件,一旦某个器件的时钟信号下跳为低电平,将使SCL线一直保持低电平,使SCL线上的所有器件开始低电平期。此时,低电平周期短的器件的时钟由低至高的跳变并不能影响SCL线的状态,于是这些器件将进入高电平等待的状态。当所有器件的时钟信号都上跳为高电平时,低电平期结束,SCL线被释放返回高电平,即所有的器件都同时开始它们的高电平期。其后,第一个结束高电平期的器件又将SCL线拉成低电平。这样就在SCL线上产生一个同步时钟。可见,时钟低电平时间由时钟低电平期最长的器件确定,而时钟高电平时间由时钟高电

5、平期最短的器件确定。4数据的传送:在数据传送过程中,必须确认数据传送的开始和结束。在I2C总线技术标准中,开始和结束信号也称启动和停止信号的定义如图2所示。当时钟线SCL为高电平时,数据线SDA由高电平跳变为低电平定义为“开始信号,起始状态应处于任何其他命令之前;当SCL线处于高电平时,SDA线发生低电平到高电平的跳变为“结束信号。器件将处于备用方式Standby MODE).开始和结束信号都是由主器件产生。在开始信号以后,总线即被认为处于忙状态;在结束信号以后的一段时间内,总线被认为是空闲的。I2C总线的数据传送格式是:在I2C总线开始信号后,送出的第一个字节数据是用来选择从器件地址的,其中

6、前7位为地址码,第8位为方向位(R/W)读写控制。方向位为“0表示发送,即主器件把信息写到所选择的从器件;方向位为“1表示主器件将从从器件读信息。开始信号后,系统中的各个器件将自己的地址和主器件送到总线上的地址进行比拟,如果与主器件发送到总线上的地址一致,那么该器件即为被主器件寻址的器件,其接收信息还是发送信息那么由第8位(R/W)确定。在I2C总线上每次传送的数据字节数不限,但每一个字节必须为8位,而且每个传送的字节后面必须跟一个应答位ACK,ACK信号在第9个时钟周期时出现。数据的传送过程如图3所示。每次都是先传最高位,通常从器件在接收到每个字节后都会作出响应,即释放SCL线返回高电平,准

7、备接收下一个数据字节,主器件可继续传送。如果从器件正在处理一个实时事件而不能接收数据时,例如正在处理一个内部中断,在这个中断处理完之前就不能接收I2C总线上的数据字节可以使时钟SCL线保持低电平,从器件必须使SDA保持高电平,此时主器件产生1个结束信号,使传送异常结束,迫使主器件处于等待状态。当从器件处理完毕时将释放SCL线,主器件继续传送。当主器件发送完一个字节的数据后,接着发出对应于SCL线上的一个时钟ACK认可位,在此时钟内主器件释放SDA线,一个字节传送结束,而从器件的响应信号将SDA线拉成低电平,使SDA在该时钟的高电平期间为稳定的低电平。从器件的响应信号结束后,SDA线返回高电平,

8、进入下一个传送周期。I2C总线还具有播送呼叫地址用于寻址总线上所有器件的功能。假设一个器件不需要播送呼叫寻址中所提供的任何数据,那么可以忽略该地址不作响应。如果该器件需要播送呼叫寻址中提供的数据,那么应对地址作出响应,其表现为一个接收器。5总线的竞争解决:总线上可能挂接有多个器件,有时会发生两个或多个主器件同时想占用总线的情况。例如,多单片机系统中,可能在某一时刻有两个单片机要同时向总线发送数据,这种情况叫做总线竞争。I2C总线具有多主控能力,可以对发生在SDA线上的总线竞争进行仲裁,其仲裁原那么是这样的:当多个主器件同时想占用总线时,如果某个主器件发送高电平,而另一个主器件发送低电平,那么发

9、送电平与此时SDA总线电平不符的那个器件将自动关闭其输出级。总线竞争的仲裁是在两个方面进行的。首先是地址位的比拟,如果主器件寻址同一个从器件,那么进入数据位的比拟,从而确保了竞争仲裁的可靠性。由于是利用I2C总线上的信息进行仲裁,因此不会造成信息的丧失。6. I2C总线接口器件:目前在仪器仪表、移动通信、密码控制等领域采用I2C总线接口器件已经比拟普遍。另外,通用的I2C总线接口器件,如带I2C总线的单片机、RAM、ROM、A/D、D/A、LCD驱动器等器件,也越来越多地应用于计算机及自动控制系统中。 AT24CXX是美国ATMEL公司的低功耗CMOS串行EEPROM,典型的型号有AT24C0

10、1A/02/04/08/16等5种,它们的存储容量分别是1024/2048/4096/8192/16384位;也就是128/256/512/1024/2048字节;使用电压级别有5V,2.7V,2.5V,1.8V;本文主要介绍常用的AT24C02即256字节存储器的使用;它具有工作电压宽2.55.5V、擦写次数多大于10000次、写入速度快小于10ms等特点。外行如图: AT24C02的1、2、3脚是三条地址线,用于确定芯片的硬件地址实验板中直接接地只有一块器件;第8脚和第4脚分别为正、负电源。第5脚SDA为串行数据输入/输出,数据通过这条双向I2C总线串行传送,SDA和SCL都需要和正电源间

11、各接一个5.1K的电阻上拉。第7脚为WP写保护端,接地时允许芯片执行一般的读写操作。接电源端时不允许对器件写。24C02中带有片内地址存放器。每写入或读出一个数据字节后,该地址存放器自动加1,以实现对下一个存储单元的读写。所有字节均以单一操作方式读取。为降低总的写入时间,一次操作可写入多达8个字节的数据。;这是将0100H地址中以下的8个数据写到24C02的01H为首址单元中去的汇编程序可直接在实验板上实验。ORG 0000HSCL BIT P3.7;定义24C02的串行时钟线SDA BIT P3.6;定义24C02的串行数据线LJMP STARTSTART:LCALL STAR;调用MOV

12、R2,#08H;一个数据有8位MOV DPTR,#0100H;定义源数据的位置LOOP:MOV A,#00HMOVC A,A+DPTRLCALL SDATALCALL ACKJC LOOPINC DPTRDJNZ R2,LOOPLCALL STOP;调用停止子程序STAR:SETB SDASETB SCLNOPNOPNOPNOPCLR SDANOPNOPNOPNOPCLR SCLRETSDATA:MOV R0,#08HLOOP0:RLC AMOV SDA,CNOPNOPSETB SCLNOPNOPNOPNOPCLR SCLDJNZ R0,LOOP0RETACK:SETB SDANOPNOPSE

13、TB SCLNOPNOPNOPNOPMOV C,SDACLR SCLRETSTOP:CLR SDANOPNOPNOPNOPSETB SCLNOPNOPNOPNOPSETB SDANOPNOPNOPNOPRETORG 0100HDB 0A0H,10H,01H,02H,03H,04H,05H,06HEND读写子程序如下:;写串行E2PROM子程序XEPR; R3=10100000命令1010+器件3位地址+读/写。 器件地址一个芯片,是000; (R4)=片内字节地址; (R1)=欲写数据存放地址指针; (R7)=连续写字节数nXEPR: MOVP3,#0FFHCLRSDA;发开始信号MOVA,R

14、3;送器件地址ACALL SUBSMOVA,R4;送片内字节地址ACALLSUBSAIN: MOVA,R1ACALL SUBS;调发送单字节子程序INC R1DJNZR7,AIN;连续写n个字节CLR SDA;SDA置0, 准备送停止信号ACALLDELAY ;延时以满足传输速率要求SETB SCL ;发停止信号ACALLDELAYSETB SDARETSUBS: MOVR0,#08H ;发送单字节子程序LOOP: CLRSCLRLCAMOVSDA,CNOPSETBSCLACALL DELAYDJNZR0,LOOP ;循环8次送8个bitCLRSCLACALL DELAYSETBSCLREP:

15、 MOVC,SDAJCREP;判应答到否,未到那么等待CLR SCLRETDELAY: NOPNOPRET;读串行E2PROM子程序DEPR;(R1)=欲读数据存放地址指针; R3=10100001命令1010+器件3位地址+读/写。 器件地址一个芯片,是000;(R4)=片内字节地址;(R7)=连续读字节数DEPR: MOVP3,#0FFHCLRSDA;发开始信号MOVA,R3;送器件地址ACALL SUBS ;调发送单字节子程序MOVA,R4;送片内字节地址ACALL SUBSMOVP3,#0FFHCLRPSDA;再发开始信号MOVA,R3SETBACC.0;发读命令ACALL SUBSM

16、ORE: ACALL SUBRMOVR1,AINCR1DJNZ R7,MORECLRP1.0ACALL DELAYSETB SCLACALL DELAYSETBSDA ;送停止信号RETSUBR: MOV R0,#08H ;接受单字节子程序LOOP2: SETB SCLACALL DELAYMOVC,SDARLCACLRSCLACALL DELAYDJNZ R0,LOOP2CJNE R7,#01H,LOWSETB SDA;假设是最后一个字节置A=1AJMP SETOKLOW: CLRSDA;否那么置A=0SETOK: ACALL DELAYSETB SCLACALL DELAYCLRSCLACALL DELAYSETBSDA ;应答毕,SDA置1RET程序中多处调用了DELAY子程序(仅两条NOP指令),这是为了满足I2C总线上数据传送速率的要求,只有当SDA数据线上的数据稳定下来之后才能进行读写(即SCL线发出正脉冲)。另外,在读最后一数据字节时,置应答信号为“1,表示读操作即将完成。 以上是介绍AT24C02的单个字节的读写操作程序,初学者在能熟练运用后可以再学习“整个页的读写。实用文档.

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服