《常用串行EEPROM的编程应用.doc》由会员分享,可在线阅读,更多相关《常用串行EEPROM的编程应用.doc(14页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、常用串行EEPROM的编程应用(一)作者:温正伟 原载:无线电本文所提供的实例程序:cdle070002.rarEEPROM是Electrically Erasable Programmable Read-only(电可擦写可编程只读存储器)的缩写,EEPROM在正常情况下和EPROM一样,可以在掉电的情况下保存数据,所不同的是它可以在特定引脚上施加特定电压或使用特定的总线擦写命令就可以在在线的情况下方便完成数据的擦除和写入,这使EEPROM被用于广阔的的消费者范围,如:汽车、电信、 医疗、工业和个人计算机相关的市场,主要用于存储个人数据和配置/调整数据。EEPROM又分并行EEPROM和串行
2、EEPROM,并行EEPROM器件虽然有很快的读写的速度,但要使用很多的电路引脚。串行EEPROM器件功能上和并行EEPROM基本相同,提供更少的引脚数、更小的封装、更低的电压和更低的功耗,是现在使用的非易失性存储器中灵活性最高的类型。串行EEPROM按总线分,常用的有I2C,SPI,Microwire总线。本文将介绍这三种总线连接单片机的编程方法。I2C总线I2C总线(Inter Integrated Circuit内部集成电路总线)是两线式串行总线,仅需要时钟和数据两根线就可以进行数据传输,仅需要占用微处理器的2个IO引脚,使用时十分方便。I2C总线还可以在同一总线上挂多个器件,每个器件可
3、以有自己的器件地址,读写操作时需要先发送器件地址,该地址的器件得到确认后便执行相应的操作,而在同一总线上的其它器件不做响应,称之为器件寻址,这个原理就像我们打电话的原理相当。I2C总线产生80年代,由PHLIPS公司开发,早期多用于音频和视频设备,如今I2C总线的器件和设备已多不胜数。最常见的采用I2C总线的EEPROM也已被广泛使用于各种家电、工业及通信设备中,主要用于保存设备所需要的配置数据、采集数据及程序等。生产I2C总线EEPROM的厂商很多,如ATMEL、Microchip公司,它们都是以24来开头命名芯片型号,最常用就是24C系列。24C系列从24C01到24C512,C后面的数字
4、代表该型号的芯片有多少K的存储位。如ATMEL的24C64,存储位是64K位,也就是说可以存储8K(8192)字节,它支持1.8V到5V电源,可以擦写1百万次,数据可以保持100年,使用5V电源时时钟可以达到400KHz,并且有多种封装可供选择。我们可以很容易的在身边的电器设备中发现它们的身影,如电视中用于保存频道信息,电脑内存条中保存内存大小等相关信息,汽车里用于保存里程信息等等。图2图二是ATMEL公司24C64的引脚定义图。A0-A2用于设置芯片的器件地址,在同一总线上有多个器件时,可以通过设置A0-A2引脚来确定器件地址。SDA是串行数据引脚,用于在芯片读写时输入或输出数据、地址等,这
5、个引脚是双向引脚,它是漏极开路的,使用时需要加上一个上拉电阻。SLC脚是器件的串行同步时钟信号,如果器件是使用在单片机系统中,那么SLC脚应该由单片机控制,根据单片机的程序要求产生串行同步时钟信号,控制总线的存取。WP脚是写保护脚,当这个脚接入高电平时,芯片的芯片数据均处于禁止写入状态(所禁止的地址段要看各芯片的详细资料),当把WP脚接到地线时,芯片处于正常的读写状态。当一个电路要求正常使用时是不允许程序修改EEPROM中的数据,只有在维护设置才可以修改数据,这时可以在电路上设置WP跳线或用微处理器对WP进行控制,这样只有在特定的电路状态下才可以更改到数据。要在单片机系统中应用I2C总线的EE
6、PROM做存储设备时,先要了解I2C总线的基本驱动方法。在I2C总线空闲时,SDA和SCL应为高电平,也只有在这个条件下,微处理器才可以控制总线进行传输数据。在数据传输的刚开始时,总线要求有一个START(开始位)位做为数据开始的标识,它的要求是SCL为高时,SDA有一个从高到低的电平跳变动作,完成这个动作后才可以进行数据传输,时序图参看图三开始。传输数据时,只有在SCL为高电平时,SDA上的电平为有效数据。编写单片机向总线送数据程序时则可以在SCL还在低电平时,把数据电平送到SDA,然后拉高SCL,这时SDA不应有电平跳变,延时后拉低SCL,再进行下一位的数据传送直到完成。在总线上读数据时也
7、是只有在SCL为高时,SDA为有效数据。时序参看图三保持。传送数据完成后,总线要有一个STOP(结束位)位,来通知总线本次传输已结束,它的要求是SCL为高时,SDA有一个从低到高的电平跳变动作,正好和START位相反。在编程时要注意的是:不要在SCL为高时改变SDA的电平状态,否则可能会被误认为是停止位,而使得操作失败。图3I2C总线在每接收完一个字节(8个二进制位)后,在第九个时钟信号时,会在SDA上回应一个低电平的ACK应答信号,以此表明当前受控的器件已接收完一个字节,可以开始下一个字节的传送了。时序图可以参看图四。单片机编程时可以在传送完一个字节后,把连接SDA的IO口线设置回读数据状态
8、,如使用51系列的单片机时就要把IO口置高电平。然后在SCL操作一个脉冲,在SCL为高时读取SDA,如不为低电平就说明器件状态不空闲或出错。需要注意因为SDA是双向的IO,无论是微处理器接收还是器件接收,每个字节完成后,接收方都可以发送一个ACK回应给发送方。 图4I2C总线在操作受控器件时,需要先发送受控器件的器件地址,24系列的EEPROM也不例外,在每次命令前需要先发送一个字节的器件地址和读写标识,也可称为器件录址。图五是24C64的器件寻址命令中每个位所代表的意思。A2、A1、A0位是器件地址,它是对应于芯片的A2、A1、A0引脚,也就是说如果芯片A0引脚被设置成高电平时,在发送器件地
9、址命令时字节中的A0位要设置为1,A0引脚为低电平时A0位设置为0。这样不难看出在同一总线可以挂8个24C64。ATMEL公司的24C系列芯片24C32及以上的型号使用16位地址进行寻址。24C32之前的型号因为使用的是8位地址,所以在超过256字节的8位地址型号中会占用到A0、A1、A2位的来做页地址,每页有256字节,以此解决地址位不足的问题。所以不同的型号器件地址位定义就有所不同,各型号的器件地址字节定义如图五至图七。要注意的是24C01是没有器件地址的,还有24C16/16A的A0A2已被页地址占用完,也就是说这三个型号的芯片只能在同一总线上挂一个,所以在设计电路选择器件时要注意这个问
10、题。器件地址字节中的R/W位是用于标识当前操作是读器件还是写器件,写器件时R/W位设置0,读器件时R/W位设置1。图5图6图724C系列芯片的读写指令格式只有几种,下面以24C64芯片的指令格式来说明。写入单个字节写入字节指令每次只能向芯片中的一个地址写入一个字节的数据。首先发送开始位来通知芯片开始进行指令传输,然后传送设置好的器件地址字节,R/W位应置0,接着是分开传送十六位地址的高低字节,再传送要写入的数据,最后发送停止位表示本次指令结束。图八是写入单个字节的时序图。图8(点击看大图)页写入24C64支持32字节的页写入模式,它的操作基本和字节写入模式一样,不同的是它需要发送第一个字节的地
11、址,然后一次性发送32字节的写入数据后,再发送停止位。写入过程中其余的地址增量自己由芯片内部完成。图九页写入的时序图。无论那种写入方式,指令发送完成后,芯片内部开始写入,这时SDA会被芯片拉高,直到写入完成后SDA才会重新变的有效,在编写微处理器程序时可以在写入的时候不停发送伪指令并查询是否有ACK返回,如果有ACK返回则可以进行下一步操作。图9(点击看大图)读当前地址这种读取模式是读取当前芯片内部的地址指针指向的数据。每次读写操作后,芯片会把最后一次操作过的地址作为当前的地址。在这里要注意的是在微处理器接收完芯片传送的数据后不必发送给低电平的ACK给芯片,直接拉高SDA等待一个时钟后发送停止
12、位。图十是读当前地址时序图。图10读任意地址读当前地址可以说是读的基本指令,读任意地址时只是在这个基本指令之前加一个伪操作,这个伪操作传送一个写指令,但这个写指令在地址传送完成后就要结束,这时芯片内部的地址指针指到这个地址上,再用读当前地址指令就可以读出该地址的数据。图十一是读任意地址的时序图图11(点击看大图)连续读取连续读取操作时只要在上面二种读取方式中芯片传送完读取数据后,微处理器回应给芯片一个低电平的ACK应答,那么芯片地址指针自动加一并传送数据,直到微处理器不回应并停止操作。图十二是连续读取的时序图。图12(点击看大图)ATMEL公司的24C系列的其它型号的读写操作方式基本和上面介绍
13、的相同,只是在8位寻址的芯片中地址位只用一个字节,还有就是在24C01中没有器件地址,地址位只占用高7位,最低位为R/W位.。其它公司的24系列的EEPROM芯片的驱动方式也基本和以上所介绍的一样。常用串行EEPROM的编程应用(二)作者:温正伟 原载:磁动力电子本文所提供的实例程序和EEPROM读写器程序:cdle070004.rarMicrowire总线Microwire总线是美国国家半导体公司研发的一种简单的串行通讯接口协议,该总线是采用三线进行数据传输。Microwire总线和SPI总线一样数据输入输出分别使用一根引线,同样可以提供同步数据传输方式,可以适用在多种微控制器、EEPROM
14、或ADC等场合。常用EEPROM的93系列芯片就是采用该总线的芯片,采用COMS技术,体积小巧,和24、25系列芯片一样也是一种理想的低功耗非易失性存储器。常见的93系列EEPROM存储器容量从256位到16K位。93芯片广泛使用在各种家电、通讯、交通或工业设备中,通常是用于保存设备或个人的相关设置数据。如最常见到网卡上的93芯片就是用于保存网卡的MAC物理地址、供应商名称以及相关配置。生产93系列芯片的公司也有很多。如ATMEL公司生产的93C46芯片是该公司生产的93系列芯片的一种,它有1K位的存储空间,93系列有二种数据输入输出模式,分别为8位和16位数据模式,1K位的存储位就可以分为1
15、288和6416,它的电压范围是2.7V到5.5V和1.8V到5.5V,可以适应低电压的应用,在5V的电压下最高时钟频率可以达到2M,芯片可以进行一百万次的擦写,数据可以保存一百年。图一是93C46的PID封装和用于网卡的93LC46芯片。图1图2图二是ATMEL公司的93C46的PID封装引脚图。CS引脚为片选引脚,高电平为有效,用于同一总线上不同芯片的选择。在执行每一个指令之前先要把CS拉高,指令完成后把CS拉低使芯片进入复位休眠状态,CS为低时,芯片保持复位状态。在连续操作多个指令时,指令与指令间,CS必须要有不小于一个TCS时间的低电平保持,使芯片复位。ATMEL公司的93C46芯片工
16、作电压2.7V5.5V的型号TCS不能小于250ns,工作电压1.8V5.5V的型号TCS不能小于1000ns。SK是串行时钟输入引脚。DI是串行数据输入引脚,接收微控制器传向芯片的数据、地址和命令数据。DO是串行数据输出引脚。ORG引脚是内部数据结构选择输入引脚,该脚为高电平时数据结构为16,低电平时数据结构为8,DC是空脚。图3(点击看大图)图三是93C46芯片的MicroWire总线时序图。在编写驱动程序前,先要分析一下这个时序图。从图中可以看到,在CS被拉高至少tCSS时间(CS初始时间)后,才能开始在SK上传送时钟信号,时钟的正半周和负半周时间不能小于tSKH和tSKL。最后一个时钟
17、的正半周发送完后CS仍要保持tCSH时间(CS保持时间)后才可以拉低CS,tCSH的最小值可为0。指令输入时数据在SK的负半周低电平时开始设置,图中的tDIS(DI设置时间),在SK的高电平时至少保持tDIH时间(DI保持时间)。在图中第四条时序线图中则可以看到在芯片读操作时DO输入1或0时的时序,可以看出在SK上升沿开始后tPD0或tPD1时,DO才输出数据,在编写驱动时就要注意读DO时可在SK拉高好延时tPD0(tPD1)后才读取DO的值,否则会造成误读。第五条时序线图则时指芯片编程时在CS上升沿开始tSV时间后DO输出状态值,tDF是指CS下降沿开始到tDF时间后才进入高阻态。因为不同的
18、芯片型号、工作电压和工作频率这么参数值都会有所不同,93C46的具体参数可以参看光盘中的芯片资料。93C46有7个操作指令,微处理器就是靠发送这几个指令来实现芯片的读写等功能。表一是93C46的指令表。在93C的其它型号中指令基本是一样,所不同的是地址位的长度,在使用时要查看相关芯片资料,得知地址位长度后再编写驱动程序。因为93C的数据结构有两种,所以地址位和数据位会有x8x16两种模式,这在编程时也是要注意的。在ERASE、WRITE、ERAL、WRAL指令之前必须先发送EWEN指令,使芯片进入编程状态,在编程结束后发EWDS指令结束编程状态。指令起始位命令代码地址位数据位说明x8x16x8
19、x16READ110A6-A0A5-A0读取指定地址数据EWEN1011xxxxx11xxxx擦写使能ERASE111A6-A0A5-A0擦除指定地址数据WRITE11A6-A0A5-A0D7-D0D15-D0把数据写到指定地址ERAL1010xxxxx10xxxx擦除所有数据,只在Vcc为4.5V-5.5V有效WRAL1001xxxxx01xxxxD7-D0D15-D0写指定数据到所有地址,只在Vcc为4.5V-5.5V有效EWDS1000xxxxx00xxxx擦写禁止表1READ(读数据)所有的指令的第一位为START(起始位),芯片确认起始位的条件是:CS和DI为高电平时,SK的第一个脉
20、冲高电平时DI仍为高电平。微控制器发送完起始位后就可以输入7种指令所需的命令代码、地址码和数据来完成指令操作。READ指令在发送完地址码AN-A0后(地址码位数位要根据型号和所选用的数据结构来确定),DO从高阻态变为低电平,在随后的一个SK脉冲后在DO输出DN-DO的数据(数据位数由所选用的数据结构来确定),微控制器在这时读取DO取得数据,读取完数据后拉低CS结束指令。图4(点击看大图)EWEN(擦写使能)芯片上电后就进入EWDS擦写禁止状态,这时要进行擦写指令,微控制器必须先要发送EWEN指令,使能芯片进入允许擦写的状态,否则操作任何擦写指令都是无效的。在完成擦写操作后发送EWDS指令,使芯
21、片进入禁止擦写的状态,这样可以防止因干扰或其它原因造成的数据错误。要注意的是:在第一个EWEN指令后芯片一直保持在擦写允许状态,直到使用EWDS或开断电源,芯片才会重新进入擦写禁止状态。图5(点击看大图)EWDS(编程禁止) 图6(点击看大图)WRITE(写入数据)WRITE指令在发送完数据位后,CS至少拉低tCS时间再拉高,这时DO会从高阻态变为低电平来指示芯片正在进行编程,微控制器应在这时检测DO,当DO再次拉高时芯片编程完成芯片进行就绪状态,这时才可以进行下一个指令。芯片编程所需的时间为tWP,这个时间最大为10MS,所以微控制器在对芯片编程时最好用一个循环检测DO,当检测到高电平时,说
22、明写入过程结束,应该退出循环体。如果循环体循环10MS后仍然没有检测到高电平时,说明有故障引起操作超时,这时要退出循环体,以免进入死循环。这样的代码在前面文章的例子中也是有使用的。WRAL指令和WRITE指令对写入过程的处理方式是一样的,不一样的是WRAL是把数据写入到所有地址中,时间会长点,而且要求电源在4.5-5.5V。图7(点击看大图)WRAL(全部写入) 图8(点击看大图)ERASE(擦除数据)ERASE指令可以说是另一种形式的写入指令,所不同的是它不用发送数据,它会把指定地址的所有数据位都置1,也就是相当于用WRITE写入FF。而ERAL指令就是相当于用WRAL写入FF,同样ERAL
23、也需要工作在4.5-5.5V电源下。图9(点击看大图)ERAL(擦除所有数据)图10(点击看大图)常用串行EEPROM的编程应用(三)完结篇SPI总线SPI总线(Serial Peripheral Interface串行外围设备接口总线)是三线式的串行总线,是由摩托罗拉公司所研发,使用三线进行数据传输,分别是SCK时钟引脚,SI数据输入引脚和SO数据输出引脚,另外还有CS片选引脚可以对同一总线上的芯片进行选通使用,SPI总线已被广泛使用在EEPROM、单片机和各种设备中。常用串行EEPROM中的25XX系列芯片就是使用兼容SPI总线结构,采用先进COMS技术,体积小,是一种理想的低功耗非易失性
24、存储器,广泛使用在各种家电、通讯、交通或工业设备中,通常是用于保存设备或个人的相关设置数据。ATMEL公司生产的25系列的EEPROM存储容量从1K位到256K位。其它一些芯片也会用到SPI总线,如常用的CPU监控芯片X5043、X5045就带有512字节的SPI界面EEPROM,常用于单片机系统的看门狗电路,同时也可以提供小数据量的存储,给电路设计带来很多的方便。此文将用X5045为例讲述SPI的编程应用和X5045的一些其它功能。X5045由Xicor公司出品,电压范围有2.7V到5.5V和4.5V到5.5V二个版本,擦写次数可达一百万次,最高时钟频率可达3.3MHz。图一是X5045的P
25、ID封装实物图。图1图2图二是X5045的引脚定义图。CS/WDI是片选和看门狗复位输入,当CS为高时SO引脚变为高阻态,这时可以允许其它器件共用SPI总线,同时芯片也处于休眠状态,当CS为低时芯片被选中,并从休眠状态中唤醒,可以进行读写操作。SO是串行数据输出,在读芯片时数据从此脚输出。WP是写保护引脚,当WP为低时芯片写保护,不能对芯片写操作,但其它功能不受影响。Vss是电源地。SI是串行数据输入,接收来自控制器的数据和地址。SCK是串行时钟输入,RESET是复位输出,Vcc是电源。在25芯片中还有一个HOLD引脚,此引脚的功能是保持输入脚,ATMEL公司生产25芯片的HOLD引脚是低电平
26、有效。不用此功能时,HOLD引脚要保持高电平。在芯片正在串行传输时,将HOLD拉为低电平,可以暂停进一步的传送,具体方法是SCK变低后,将HOLD也拉低,不然在下一个SCK变低前不能暂停传送,要恢复串行传送,必须在SCK为低电平时将HOLD拉高。芯片处于暂停时,SI,SO,SCK脚为高阻状态,任何时刻只要HOLD被拉低时,SO都会处于高阻状态。限于文章的篇幅,下面内容只着重介绍X5045芯片的SPI总线对EEPROM单元的编程应用。在X5040芯片中有6个指令,它和25系列芯片的指令是兼容的,也就是说在25系列芯片中使用时基本上是不需要改变的,具体见表一。指令指令格式说明WREN0000 01
27、10写入允许WRDI0000 0100写入禁止RSDR0000 0101读状态寄存器WRSR0000 0001写状态寄存器,用于操作区块写保护标识和看门狗标识READ0000 A8011读数据WRITE0000 A8010写数据注:A8用于数据地址的第9位。 表一指令集写入允许和禁止X5045芯片内部有一个写入使能寄存器,在需要向芯片写入数据时,需要先用WREN指令使片内写入使能寄存器先置位,写入数据后可以用WRDI指令使寄存器复位到禁止状态。当上电、WRSR指令执行、WRITE指令执行、WP拉低也会使写入使能寄存器复位到禁止状态。图三是WREN/WRDI指令的操作时序图。首先要把CS拉低,输
28、入数据,向SCK输入时钟信号,数据在时钟的上升沿有效,时钟上升后至少数据至少保持30ns。数据是串行的,所以在每个时钟周期的上升沿发送一个位。在操作这两个指令时,SO是处于高阻状态的。图3写入使能时序读写状态寄存器X5045片内有一个状态寄存器,用于指于芯片的状态和设置,可以读写,芯片出厂时状态寄存器值为30H。具体每位的功能请看表2。WIP写入保护位,是只读位,指示芯片是否正忙于写入操作。当WIP为1时,说明写入正在进行,为0时表示没有进行写入。在编程时,写入数据操作后,可以查询WIP位,当WIP为0后才进行下一次的写入操作,这样可以避免写入出错。WEL写入使能状态位,是只读位。WEL位的状
29、态由WREN和WRDI指令确定,WREN成功执行后WEL为1指示允许写入数据,WRDI指令成功执行后WEL为0指示禁止写入数据。在编程时可以先查询WEL位的状态,如为0时则要执行WREN后才可以进行写入操作。BL0、BL1设置当前保护的区块地址,是可读写位,这两个位的设置和区块地址的关系如表3,区块的内容被保护后,就只能读出而不能写入了。25系列芯片中不同型号的芯片容量不一样,BL设置所保护的范围也不一样。WD1、WD0看门狗设置位是X5045/43特有的设置位,是可以读写位,在25系列芯片中这两个位是保留位,在X5045中有看门狗功能,这两个位就用于设置MCU喂狗的时间,表4是看门狗位的设置
30、时间。状态寄存器的第6和第7位是保留位。读状态寄存器时,发送完RSDR指令后,SO由高阻态转为输出数据,从数据位的高位开始。写状态寄存器,发送完WSDR指令后,再发一个字节的状态数据就可以了,其中只读位可以是1也可以是0,它们不会被WSDR指令所更改。图5、图6是读写状态寄存器的时序图。7654321000WD1WD0BL1BL0WELWIP00看门狗位1看门狗位0区块保护1区块保护0写入使能状态位写入保护位表2状态寄存器定义BL1BL0保护地址范围00无保护01180H1FFH10100H1FFH11000H1FFH表3BL设置位WD1WD0喂狗时间001.4秒01600毫秒10200毫秒1
31、1功能禁用(出厂设置)表4看门狗设置位图4读状态寄存器时序图5写状态寄存器时序读数据图6是读数据时的时序,先拉低CS选中芯片,先要把需读取的地址的第9位加到指令字节的第4个字节中,发送完指令字节就发送地址字节的前8位,这时SO就会由高阻态转为输出数据。每当一个字节的数据传送完毕后,芯片内部的地址指针自动加1,指向下一个数据地址,这时如仍有时钟脉冲时,数据会被继续输出,CS脚拉高后输出才会终止。当最高位地址的数据被读出后,地址指针指向00H。图6读数据时序(点击看大图)写数据在向芯片写入数据之前,写使能寄存器必须处于置位状态,一般可以不必查询写使能寄存器的状态,而直接用WREN置位写使能寄存器。
32、在发送完WREN指令后,必须把CS拉高,在CS拉高之前写使能寄存器并没有置位,这时向芯片传送数据是不会被写入的。写使能寄存器置位后,再将CS拉低,把需读取的地址的第9位加到指令字节的第4个字节中,发送完指令字节就发送地址字节的前8位,然后发送需写入的数据。WRITE指令可以连续写入16个字节,但这16个字节的地址必须在同一页中。每一页的地址由xxxxx0000开始,到xxxxx1111结束。操作方法就是在发送完每一个地址和数据后,继续发后面的数据,芯片内部的地址指针会自动累加,当达到页中最后一个字节时,时钟仍在继续,则内部地址指针回到页中第一个地址重新开始累加,并覆盖以前写入的数据。要注意的是,在操作过程中CS不能拉高,只有在数据字节的最后一个位传送完成后才可以拉高CS,不然写入操作将不完全。在写入数据或写状态寄存器指令写送后,芯片会进入一次非易失性写操作,这会花费一定的时间,最大约为10ms,在这个时间内可以用读状态寄存器,并检查WIP位,当WIP为1时则说明写入还在进行中,只有当WIP位为0时才可以进行下一次的读写数据操作,否则将会使写入不完全。