I2C总线at24c02芯片使用说明
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
3.2.5 密码储存电路
密码储存电路采用I2C总线at24c02存储芯片存放密码,可实现断电密码不消失,at24c02存储芯片可长期存储信息,可上百万次以上重新擦写。
图3-5 密码储存电路
2.4.3 I2C总线密码存储芯片at24c02介绍
图2-3 at24c02引脚图
(1)引脚功能介绍及相关知识
WP:写保护引脚,将该引脚接VCC E2PR0MI就实现写保护(只读)。
引
脚接地或悬空,可以对器件进行读写操作。
SCL串行时钟引脚,串行输入输出时该引脚用于输入时钟。
SDA串行数据输入输出引脚,用来输入输出数据,该引脚为射极开路输出,需接上拉电阻。
(2)I2C总线协议
只有总线非忙时才被允许进行数据传送,在传送时,当时钟线为高电平,数据线必须为固定状态,不允许有跳变。
时钟线为高电平时数据线的任何电平变化将被当作总线的启动或停止条件。
(3)起始条件
起始调教必须在所有操作命令之前发送。
时钟线保持高电平期间,数据线电平从高到低跳变作为I2C总线的启动信号。
CAT24Cxx>一直监视SDA和SCL电平信号,直到条件满足时才响应。
(4)停止条件
时钟线保持高电平期间,数据线电平从低到高跳变作为IC总线的停止信号。
(5)器件地址的约定
主器件在发送启动命令后开始传送数据,主器件发送相应的从器件地址,8 位从器件地址的高四位固定为1010,接下来的 3 位用来定义存储器的地址,对2
于,这三位无意义,对于,接下来的 2 位无意义,第三位是地址高位,中,第一位无意义,后两位表示地址高位。
最后一位为读写控制位,“1表”示对从器件进行读写操作,“0表”示写操作。
在主器件发送启动命令和一字节从器件地址后,如果与从器件地址吻合,
CAT24C02各发送一个应答信号,然后再根据读/写控制为进行读或写操作。
(6)应答信号
每次数据传送成功后,接收器件将发送一个应答信号。
当第九个时钟信号产生时,产生应答型号的器件将SDA下拉为低,通知已经接受到8位数据,接收到起始条件和从器件地址后,CAT24C02发送一个应答信号,如果为写操作,每接收到一个字节数据,CAT24C02发送一个应答信号。
如果为读操作,CAT24C02发送一个字节数据后释放总线等待应答信号,一旦接收到应答信号,它将继续发发送数据,如果接收到主器件发送非应答信号,将结束数据传送等待停止条件。
(7)写操作
在写字节模式下,助器件发送起始命令和从器件地址信息给从器件,在从器件响应应答信号后,主器件将要写入的数据地址发送到CAT24C02的地址指针,主器件收到从器件的应答信号后再送数据到相应的数据存储区地址,CAT24C02再响应一个应答信号,主器件产生一个停止信号,然后CAT24C02启动内部写周期,在内部写周期期间,CAT24C02不再响应主器件任何请求。
写操
作时序读如图2-4所示:
图2-4 写时序图
(8)读操作
CAT24C02卖操作的初始化方式和写操作一样,仅把R/W位置1,读操作有三种方式:立即地址读、选择地址读、连续读。
选择地址读操作时序图如图2-5 所示:
图2-5 读时序图
程序:
#include<>
#include<>
#define uint unsigned int
#define uchar unsigned char uchar i,date;
password [6];
uchar code deposit []={3,2,5,8,9,2}; sbit sda=P3A4;
sbit scl二卩3八5;
void nopp(uchar s)
{uchar n;
}
void start() // 开始信号{sda=1;
}
void stop() // 停止信号nopp(5);
nopp(5);
sda=0;
nopp(5);
for(n=0;n<s;n++)
_nop_();
{sda=0;
}
void response() // 应答信
{uchar i;
}
void write_byte(uchar date)
// 写一个字节{uchar i,temp;
temp=date;
for(i=0;i<8;i++)
{scl=0;
nopp(5);
temp<<=1;
sda=CY;
nopp(5);
scl=1;
scl=1;
nopp(5);
while((sda==1)&&(i<255))i++;
nopp(5);
nopp(5);
scl=1;
nopp(5);
sda=1;
nopp(5);
}}nopp(5);
scl=0;
nopp(5);
sda=1;
nopp(5);
uchar read_byte() // 读一个字节
{uint i,j;
}
void at24_write(uchar address,uchar date)
{ start(); // 初始信号write_byte(0xa0); // 写入芯片地址0XA0
nopp(5);
sda=1;
nopp(5);
for(i=0;i<8;i++) // 循环8 次读出一个字节数据{scl=1;
}
return j;nopp(5);
j=(j<<1)|sda;
scl=0;
nopp(5);
}response(); write_byte(address); ADDRESSresponse(); write_byte(date);
response(); stop();
uchar at24_read(uchar address) {uchar
date;
}
void main()
{uchar tt, i ,r
// 应答信号
// 写入芯片内部寄存器地址
// 应答信号
// 写入数据
// 应答信号
// 停止信号
scl=1;
at24_write(8,9);〃向at24c02 的地址8 写入数据9
start();// 初始信号
write_byte(0xa0);// 写入芯片地址0XA0 response();//应答信号
write_byte(address); ADDRESSresponse();// 写入芯片内部寄存器地址// 应答信号
start();// 初始信号
write_byte(0xa1);// 初始信号
response();//写入芯片地址0XA1 (读) date=read_byte();//读出数据
stop();// 停止信号
return date;//返回读出值
delay(50);
for(i=0;i<6;i++)〃将数组中的数据写入at24c02的地址为0至5的位置{at24_write(i,deposit[i]);
}
tt=at24_read(8);// 读地址8 中的数据
delay(50);
for(r=0;r<6丁++)//读取地址为0至5的数据,存放在数组password中
}password[r]=at24_read(r);。