EEPROM是“Eleally Eras-able Programmable Read-only”(电可擦写可编程只读)的缩写,EEPROM在正常情况下和EPROM-样,可以在掉电的情况下保存数据,所不同的是,它在特定引脚上施加特定或使用特定的总线擦写命令就可以在在线的情况下方便地完成数据的擦除和写入,这个特点使EEPROM被用于广阔的消费领域,如汽车、电信、医疗、工业和个人计算机相关的市场,主要用于存储个人数据和配置/调整数据
。EEPROM又分并行EEPROM和串行EEPROM,并行EEPROM器件虽然有很快的读写速度,但要使用很多引脚,电行EEPROM器件功能上和并行EEPROM基本相同,却可以提供更少的引脚数、更小的封装、更低的电压和更低的功耗,是现在使用的非易失性存储器中灵活性最高的类型。串行EEPROM按总线分,常用的有I2C、SPI、Microwire总线。本文将介绍这三种总线连接的编程方法。
阳总线 I2C总线(Inter Integrated Circuit内部总线)是两线式串行总线,仅需要时钟和数据两根线就可以进行数据传输,仅需要占用的2个I/O引脚,使用时十分方便。I2C总线还可以在同一总线上挂多个器件,每个器件可以有自己的器件地址,读写操作时需要先发送器件地址,该地址的器件得到确认后便执行相应的操作,而在同一总线上的其他器件不做响应,称之为器件寻址,这个原理就与我们打电话的原理相当。
I2C总线产生于上世纪80年代,由PHILIPS公司开发,早期多用于音频和视频设备,如今I2C总线的器件和设备已多不胜数。最常见的采用I2C总线的EEPROM也已被广泛使用于各种家电、工业及通信设备中,主要用于保存设备所需要的配置数据、采集数据及程序等,如电视机中用于保存频道信息,电脑内存条中保存内存大小等相关信息,汽车里用于保存里程信息等。生产FC总线EEPROM的厂商很多,如ATMEL、Micro公司,它们都是以24来开头命名芯片型号,最常用的是24C系列。24C系列从24C01到24C512,C后面的数字代表该型号的芯片有多少K的存储位。如ATMEL的24C64,存储位是64K位,也就是说可以存储8K(8192)字节,它支持1.8V~5V,可以擦写1百万次,数据可以保持100年,使用5V电源时时钟可以达到400k,并且有多种封装可供选择。图1就是ATMEL24C64芯片的PID封装和用于内存条SPD(Serial Presence Detect)上的24芯片。
图2是ATMEL公司24C64的引脚定义图。A0~A2用于设置芯片的器件地址,在同一总线上有多个器件时,可以通过设置A0~A2引脚来确定器件地址。SDA是串行数据引脚,用于在芯片读写时输入或输出数据、地址等,这个引脚是双向引脚,它是漏极开路的,使用时需要加上一个。 SCL脚是器件的串行同步时钟信号,如果器件是使用在单片机系统中,那么SCL脚应该由单片机控制,根据单片机的程序要求产生串行同步时钟信号,控制总线的存取。
WP脚是写保护脚,当这个脚接入高时,芯片中的数据均处于禁止写入状态(所禁止的地址段要看各芯片的详细资料),当把WP脚接到地线时,芯片处于正常的读写状态。
当一个电路正常使用时是不允许程序修改EEPROM中的数据的,除非在维护设置时才可以修改数据。只有在特定的电路状态下,在电路上设置WP跳线或用微处理器对WP进行控制,才可以更改数据。
要在单片机系统中用I2C总线的EEPROM作存储设备时,先要了解I2C总线的基本驱动方法。在FC总线空闲时,SDA和SCL应为高电平,也只有在这个条件下,微处理器才可以控制总线进行传输数据。在数据传输刚开始时,总线要求有一个START(开始位)位作为数据开始的标识,它的要求是,SCL为高电平时,SDA有一个从高到低的电平跳变动作,完成这个动作后才可以进行数据传输,时序图参看图3“开始”部分。传输数据时,只有在SCL为高电平时,SDA上的电平为有效数据。编写单片机向总线送数据程序时,测可以在SCL还在低电平时,把数据电平送到SDA,然后拉高SCL,这时SDA不应有电平跳变,延时后拉低SCL,再进行下一位的数据传送直到完成。在总线上读数据时也是只有在SCL为高电平时,SDA为有效数据。时序参看图3“保持”部分。
传送数据完成后,总线要有一个STOP(结束位)位,来通知总线本次传输已结束,它的要求是,SCL为高时,SDA有一个从低到高的跳变动作,正好和START位相反。在编程时要注意:不要在SCL为高电平时改变SDA的电平状态,否则可能会被误认为是停止位,而使得操作失败。 FC总线每接收完一个字节(8个位)后,在第9个时钟信号时,会在SDA上回应一个低电平的ACK应答信号,以此表明当前受控的器件已接收完一个字节,可以开始下一个字节的传送了。时序图可以参看图4。
编程时可以在传送完一个字节后,把连接SDA的I/O口线设置回读数据状态,如使用51系列的单片机时就要把I/O口置高电平,然后在SCL.脚设置一个脉冲,在SCL为高电平时读取SDA,如不为低电平就说明器件状态不空闲或出错。需要注意,因为SDA是双向的I/O,无论是接收还是器件接收,每个字节完成后,接收方都可以发送一个ACK回应给发送方。 I2C总线在操作受控器件时,需要先发送受控器件的器件地址,24景列的EEPROM也不例外,在每次命令前需要先发送一个字节的器件地址和读写标识,也可称为器件录址。图5是24C64的器件寻址命令中每个位所代表的意思。A2、A1、A0位是器件地址,它是对应于芯片的A2、A1、A0引脚,也就是说如果芯片A0引脚被设置成高电平时,在发送器件地址命令时字节中的A0位要设置为1,A0引脚为低电平时A0位设置为0。这样在同一总线上就可以连接8个24C64。 ATMEL公司的24C系列芯片24C32及以上的型号使用16位地址进行寻址。24C32之前的型号因为使用的是8位地址,所以在超过256字节的8位地址型号中会占用到A0、A1、A2位来做页地址,每页有256字节,以此解决地址位不足的问题。所以不同型号的器件地址位定义就有所不同,各型号的器件地址字节定义见图5~图7。 在设计选择器件时要注意的是,24C01是没有器件地址的,还有24C16/16A的A0~A2已被页地址占用完,也就是说这三个型号的芯片只能在同一总线上连接一个。器件地址字节中的R/W位是用于标识当前操作是读器件还是写器件,写器件时R/W位设置0,读器件时R/W位设置1。 24C系列芯片的读写指令格式只有几种,下面以24C64芯片的指令格式来说明。 写入单个字节 写入字节指令每次只能向芯片中的一个地址写入一个字节的数据。首先发送开始位来通知芯片开始进行指令传输,然后传送设置好的器件地址字节,R/W位应置0,接着是分开传送十六位地址的高低字节,再传送要写入的数据,最后发送停止位表示本次指令结束。图8是写入单个字节的时序图。 页写入 24C64支持32字节的页写入模式,它的操作和字节写入模式基本一样,不同的是它需要发送第一个字节的地址,然后一次性发送32字节的写入数据后,再发送停止位。写入过程中其余的地址增量由芯片内部完成。 图9为页写入的时序图。无论哪种写入方式,指令发送完成后,芯片内部才开始写入,这时SDA会被芯片拉高,直到写入完成后SDA才会重新变得有效,在编写微处理器程序时可以在写入的时候不停地发送伪指令并查询是否有ACK返回,如果有ACK返回则可以进行下一步操作。 读当前地址 这种读取模式是读取当前芯片内部的地址指针指向的数据。每次读写操作后,芯片会把最后一次操作过的地址作为当前的地址。在这里要注意的是在微处理器接收完芯片传送的数据后不必发送低电平的ACK给芯片,直接拉高SDA等待一个时钟后发送停止位。图10是读当前地址时序图。 读任意地址 “读当前地址”可以说是读的基本指令,读任意地址时只是在这个基本指令之前船一仑“伪操作”,这个伪操作传送一个写指令,但这个写指令在地址传送完成后就要结束,这时芯片内部的地址指针指到这个地址上,再用读当前地址指令就可以读出该地址的数据。图11是读任意地址的时序图。 连续读取 连续读取操作时只要在上面两种读取方式中芯片传送完读取数据后,微处理器回应给芯片一个低电平的ACK.应答,那么芯片地址指针自动加1并传送数据,直到微处理器不回应并停止操作。图12是连续读取的时序图。
ATMEL公司的24C系列的其他型号的读写操作方式和上面介绍的基本相同,只是在8位寻址的芯片中地址位只用一个字节,还有就是在24C01中没有器件地址,地址位只占用高7位,最低位为R/W位。其他公司的24系列EEPROM芯片的驱动方式也和以上所介绍的基本一样。 图13是笔者设计的制作简单的24C读写器。可以用它来做24C芯片的驱动程序编写实验,也可以配合上位机程序(见本期配刊光盘“EEPROM读写器”)进行24C的读写。 该读写器的电路由一片AT89C2051芯片作为主控芯片,用于连接电脑的RS232和驱动24C芯片,使用11.0592M。RS232由两个三极管组成。部分则直接在RS232上的4、7引脚取电,取电时需要在用软件控制这两脚为+9V~+12V之间,再通过VD5稳压得到5.1V,无需外加电源。