




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、A0VCCA1wpA2sclGNDa76 scl5 sdaRIO 5.1k325密码储存电路密码储存电路采用I2C总线at24c02存储芯片存放密码,可实现断电密码不消失,at24c02存储芯片可长期存储信息,可上百万次以上重新擦写。VCC 1f-u4 AT2-4CO2图3-5密码储存电路2.4.3 I 2C总线密码存储芯片at24c02介绍S-bad TSSOP(1)引脚功能介绍及相关知识WP写保护引脚,将该引脚接 VCC WPROM就实现写保护(只读)。引脚接 地或悬空,可以对器件进行读写操作。SCL串行时钟引脚,串行输入输出时该引脚用于输入时钟。SDA串行数据输入输出引脚,用来输入输出数
2、据,该引脚为射极开路输出, 需接上拉电阻。AOCAOC1 1s.AlAl匚2 27炮匚3 36 6GNDGND匚4 45 5V VCCCC J J WPWPS SCLCLS SDADA图2-3 at24c02 引脚图IT! J M l14精选文库2(2)|2C总线协议只有总线非忙时才被允许进行数据传送, 在传送时,当时钟线为高电平,数 据线必须为固定状态,不允许有跳变。时钟线为高电平时数据线的任何电平变化 将被当作总线的启动或停止条件。(3)起始条件起始调教必须在所有操作命令之前发送。 时钟线保持高电平期间,数据线电 平从高到低跳变作为I2C总线的启动信号。CAT24CXX)一直监视SDA和S
3、CL电平 信号,直到条件满足时才响应。精选文库3CAT24C02CAT24C02启动内部写周CAT24C02不再响应主器件任何请求。写操作时序读如BUSACTIVFTV;BUSACTIVFTV;MASTERMASTERS ST TA A SLAVESLAVER R ADDRESSADDRESSSDASDA LINELINEAC-KACKACKACKACK(4)停止条件时钟线保持高电平期间,数据线电平从低到高跳变作为12c总线的停止信号。(5)器件地址的约定主器件在发送启动命令后开始传送数据,主器件发送相应的从器件地址,8位从器件地址的高四位固定为1010,接下来的3位用来定义存储器的地址,对
4、于CAT24C021/022这三位无意义,对于 CAT24C41/042接下来的2位无意义, 第三位是地址高位,CAT24C081/082中,第一位无意义,后两位表示地址高位。最后一位为读写控制位,“ 1”表示对从器件进行读写操作,“ 0 ”表示写操 作。在主器件发送启动命令和一字节从器件地址后,如果与从器件地址吻合, CAT24C02各发送一个应答信号,然后再根据读/写控制为进行读或写操作。(6)应答信号每次数据传送成功后,接收器件将发送一个应答信号。当第九个时钟信号产 生时,产生应答型号的器件将SDAT拉为低,通知已经接受到8位数据,接收到 起始条件和从器件地址后,CAT24C02发送一个
5、应答信号,如果为写操作,每接 收到一个字节数据,CAT24C02发送一个应答信号。如果为读操作,CAT24C0发 送一个字节数据后释放总线等待应答信号,一旦接收到应答信号,它将继续发发送数据,如果接收到主器件发送非应答信号,将结束数据传送等待停止条件。(7)写操作在写字节模式下,助器件发送起始命令和从器件地址信息给从器件,在从器件响应应答信号后,主器件将要写入的数据地址发送到CAT24C02的地址指针,主器件收到从器件的应答信号后再送数据到相应的数据存储区地址, 再响应一个应答信号,主器件产生一个停止信号,然后 期,在内部写周期期间, 图2-4所示:图2-4写时序图BYTEBYTE ADDRE
6、SSADDRESSDATADATA精选文库4(8)读操作精选文库5仅把R/W位置1,读操作有三连续读。选择地址读操作时序图如图2-5开始信号CAT24C0读操作的初始化方式和写操作一样, 种方式:立即地址读、选择地址读、 所示:SDAUNESDAUNE程序:#in clude#in clude#define uint un sig ned int#define uchar un sig ned char uchar i,date;p assword 6;uchar code dep osit =3,2,5,8,9,2; sbit sda=P 3人4;sbit scl=P3A5;void nop
7、p( uchar s) uchar n;for(n=0;ns;n+) _nop_();void start() sda=1;nopp(5);scl=1; nopp(5);sda=0; nopp(5);RUSRUS ACTIVirV:ACTIVirV:MABTELRMABTELRBYTEBYTEADDRESSADDRESS 何SLAVESLAVEADDRESSADDRESSSTOPSTOPA A-r r DATAnDATAn K KN NO OA AC CK K图2-5读时序图精选文库6/停止信号void stop() sda=0;精选文库7nopp(5); scl=1;nopp(5); sda
8、=1;nopp(5); void respon se()/应答信号uchar i;scl=1;nopp(5);while(sda=1)&(i255)i+; scl=0;nopp(5);void write_byte(uchar date)/ 写一个字节uchar i,te mp; temp=date; for(i=0;i8;i+) scl=0; nopp(5); temp=1; sda=CY; nopp(5); scl=1; nopp(5); scl=0;nopp(5); sda=1;nopp(5);uchar read_byte() ui nt i,j;scl=0;nopp(5);sda=1
9、;nopp(5); for(i=0;i8;i+) scl=1; nopp(5); j=(j1)|sda;/读一个字节循环8次读出一个字节数据精选文库8精选文库9scl=0; nopp(5);return j;void at24_write(uchar address,uchar date) start();write_byte(0 xa0);respon se();write_byte(address);respon se();write_byte(date);respon se();sto p();/初始信号/写入芯片地址OXAO/应答信号/写入芯片内部寄存器地址ADDRESS/应答信号/写
10、入数据/应答信号/停止信号uchar at24_read(uchar address) uchar date;start();write_byte(0 xa0);respon se();write_byte(address);respon se();start();write_byte(0 xa1);respon se();date=read_byte();sto p();return date;void mai n() uchar tt, i ,rsda=1;scl=1;at24_write(8,9);/ 向 at24c02 的地址 8 写入数据 9delay(50);for(i=0;i6;i+)/将数组中的数据写入at24c02的地址为0至5的位置 at24_write(i,de positi);delay(50);/初始信号写入芯片地址OXAO应答信号写
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论