I2C总线at24c02芯片使用说明.doc
- 文档编号:2486955
- 上传时间:2022-10-30
- 格式:DOC
- 页数:6
- 大小:197.50KB
I2C总线at24c02芯片使用说明.doc
《I2C总线at24c02芯片使用说明.doc》由会员分享,可在线阅读,更多相关《I2C总线at24c02芯片使用说明.doc(6页珍藏版)》请在冰豆网上搜索。
3.2.5密码储存电路
密码储存电路采用I2C总线at24c02存储芯片存放密码,可实现断电密码不消失,at24c02存储芯片可长期存储信息,可上百万次以上重新擦写。
图3-5密码储存电路
2.4.3I2C总线密码存储芯片at24c02介绍
图2-3at24c02引脚图
(1)引脚功能介绍及相关知识
WP:
写保护引脚,将该引脚接VCC,E2PROM就实现写保护(只读)。
引脚接地或悬空,可以对器件进行读写操作。
SCL:
串行时钟引脚,串行输入输出时该引脚用于输入时钟。
SDA:
串行数据输入输出引脚,用来输入输出数据,该引脚为射极开路输出,需接上拉电阻。
(2)I2C总线协议
只有总线非忙时才被允许进行数据传送,在传送时,当时钟线为高电平,数据线必须为固定状态,不允许有跳变。
时钟线为高电平时数据线的任何电平变化将被当作总线的启动或停止条件。
(3)起始条件
起始调教必须在所有操作命令之前发送。
时钟线保持高电平期间,数据线电平从高到低跳变作为I2C总线的启动信号。
CAT24Cxxx一直监视SDA和SCL电平信号,直到条件满足时才响应。
(4)停止条件
时钟线保持高电平期间,数据线电平从低到高跳变作为I2C总线的停止信号。
(5)器件地址的约定
主器件在发送启动命令后开始传送数据,主器件发送相应的从器件地址,8位从器件地址的高四位固定为1010,接下来的3位用来定义存储器的地址,对于CAT24C021/022,这三位无意义,对于CAT24C41/042,接下来的2位无意义,第三位是地址高位,CAT24C081/082中,第一位无意义,后两位表示地址高位。
最后一位为读写控制位,“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
#defineuintunsignedint
#defineucharunsignedchar
uchari,date;
password[6];
ucharcodedeposit[]={3,2,5,8,9,2};
sbitsda=P3^4;
sbitscl=P3^5;
voidnopp(uchars)
{ ucharn;
for(n=0;n
_nop_();
}
voidstart()//开始信号
{ sda=1;
nopp(5);
scl=1;
nopp(5);
sda=0;
nopp(5);
}
voidstop()//停止信号
{ sda=0;
nopp(5);
scl=1;
nopp(5);
sda=1;
nopp(5);
}
voidresponse()//应答信号
{ uchari;
scl=1;
nopp(5);
while((sda==1)&&(i<255))i++;
scl=0;
nopp(5);
}
voidwrite_byte(uchardate)//写一个字节
{ uchari,temp;
temp=date;
for(i=0;i<8;i++)
{ scl=0;
nopp(5);
temp<<=1;
sda=CY;
nopp(5);
scl=1;
nopp(5);
}
scl=0;
nopp(5);
sda=1;
nopp(5);
}
ucharread_byte()//读一个字节
{ uinti,j;
scl=0;
nopp(5);
sda=1;
nopp(5);
for(i=0;i<8;i++)//循环8次读出一个字节数据
{ scl=1;
nopp(5);
j=(j<<1)|sda;
scl=0;
nopp(5);
}
returnj;
}
voidat24_write(ucharaddress,uchardate)
{start();//初始信号
write_byte(0xa0);//写入芯片地址0XA0
response();//应答信号
write_byte(address);//写入芯片内部寄存器地址ADDRESS
response();//应答信号
write_byte(date);//写入数据
response();//应答信号
stop();//停止信号
}
ucharat24_read(ucharaddress)
{ uchardate;
start();//初始信号
write_byte(0xa0);//写入芯片地址0XA0
response();//应答信号
write_byte(address);//写入芯片内部寄存器地址ADDRESS
response();//应答信号
start();//初始信号
write_byte(0xa1);//初始信号
response();//写入芯片地址0XA1(读)
date=read_byte();//读出数据
stop();//停止信号
returndate;//返回读出值
}
voidmain()
{ uchartt,i,r
sda=1;
scl=1;
at24_write(8,9);//向at24c02的地址8写入数据9
delay(50);
for(i=0;i<6;i++)//将数组中的数据写入at24c02的地址为0至5的位置
{ at24_write(i,deposit[i]);
delay(50);
}
tt=at24_read(8);//读地址8中的数据
for(r=0;r<6;r++)//读取地址为0至5的数据,存放在数组password中
password[r]=at24_read(r);
}
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- I2C 总线 at24c02 芯片 使用说明