1〉AT24CXX芯片都是串行eeprom, 通信协议是相同的,但是容量不同。如果驱动程序考虑到了,是可以兼容的。
2〉AT24CXX没有擦除的动作,可以直接写入。但是eeprom和普通的ram还是有区别的,eeprom可以在断电后保存数据,普通的ram则不行
24C02 只能写数据,是不能写程序的。程序是单片机可执行的指令。而数据是单片机运行过程中需要的数据。要对24C02读/写数据,需要按I2C的协议写程序,那要有单片机对它进行读/写 *** 作才行的,板上有24C02,有单片机吗,那单片机是什么型号的,能给单片机烧录程序吗?如果不能烧录程序,就不能读/写24C02。至于读/写24C02的程序,百度上可以搜索到的。
板子上留的焊孔,是可以焊导线连接到单片机上,进行读/写的。要查一下这些孔是怎么连接24C02的引脚的。
你的程序编译是通过的,看你的原理图,指出两点:
1你的地址端接的是高电平,读写时是不是和0xae,0xaf地址码对应,请请查看使用说明解决。
2SCL、SDA需要接上上电阻的,不然高电平上不去。
希望对你有帮助!
只要会写入和读出即可,写入时先发一个字节为写命令(最低位是读写命令其余7位可做为高7位地址),再发一个低8位地址,然后再发要写入的数据 读出时先发一个字节为写命令(同样含高7位地址),再发一个低8位地址,然后再发一次读命令,即可读出数据. 对于24C02 高7位地址的前4位内部已规定为1010 另3位为器件上三根地址线的地址 若全接地,则为000,因此读此器件的命令即为0xa1 写此器件的命令即为0xa0 低8位刚好寻址内部256字节地址空间 下面给出单字节写入和读出的程序
/////////24C02读写驱动程序////////////////////
void delay1(unsigned char x)//24C02比较慢,要延时等待
{ unsigned int i;
for(i=0;i<x;i++);
;}
void flash()//短延时
{ ; ; }
void x24c08_init() //24c02初始化子程序
{scl=1; flash(); sda=1; flash();}
void start() //启动I2C总线
{sda=1; flash(); scl=1; flash(); sda=0; flash(); scl=0; flash();}
void stop() //停止I2C总线
{sda=0; flash(); scl=1; flash(); sda=1; flash();}
void writex(unsigned char j) //写一个字节
{ unsigned char i,temp;
temp=j;
for (i=0;i<8;i++)
{temp=temp<<1; scl=0; flash(); sda=CY; flash(); scl=1; flash();}
scl=0; flash(); sda=1; flash();
}
unsigned char readx() //读一个字节
{
unsigned char i,j,k=0;
scl=0; flash(); sda=1;
for (i=0;i<8;i++)
{ flash(); scl=1; flash();
if (sda==1) j=1;
else j=0;
k=(k<<1)|j;
scl=0;}
flash(); return(k);
}
void clock() //I2C总线时钟
{
unsigned char i=0;
scl=1; flash();
while ((sda==1)&&(i<255))i++;
scl=0; flash();
}
////////从24c02的地址address中读取一个字节数据/////
unsigned char x24c02_read(unsigned char address)
//address 要读的存储单元地址
{
unsigned char i;
start(); writex(0xa0);//写入器件地址
clock(); writex(address);) //写入读取的内部存储单元地址
clock(); start();
writex(0xa1); clock(); //再向此器件写入读命令
i=readx(); stop(); //获得数据
delay1(10);
return(i);
}
//////向24c02的address地址中写入一字节数据info/////
void x24c02_write(unsigned char address,unsigned char info)//写入时要有地址和数据2个参数
{
EA=0;
start(); writex(0xa0);
clock(); writex(address);
clock(); writex(info);
clock(); stop();
EA=1;
delay1(50);
}
24c02是串行I2 C总线EEPROM
写进去的掉电后数据不会丢失。
#include<reg52h>
#define uchar unsigned char
sbit sda=P2^0;
sbit scl=P2^1;
uchar a;
void delay()
{ ; ; }
void start() //开始信号
{
sda=1;
delay();
scl=1;
delay();
sda=0;
delay();
}
void stop() //停止
{
sda=0;
delay();
scl=1;
delay();
sda=1;
delay();
}
void respons() //应答
{
uchar i;
scl=1;
delay();
while((sda==1)&&(i<250))i++;
scl=0;
delay();
}
void init()
{
sda=1;
delay();
scl=1;
delay();
}
void write_byte(uchar date)
{
uchar i,temp;
temp=date;
for(i=0;i<8;i++)
{
temp=temp<<1;
scl=0;
delay();
sda=CY;
delay();
scl=1;
delay();
}
scl=0;
delay();
sda=1;
delay();
}
uchar read_byte()
{
uchar i,k;
scl=0;
delay();
sda=1;
delay();
for(i=0;i<8;i++)
{
scl=1;
delay();
k=(k<<1)|sda;
scl=0;
delay();
}
return k;
}
void delay1(uchar x)
{
uchar a,b;
for(a=x;a>0;a--)
for(b=100;b>0;b--);
}
void write_add(uchar address,uchar date)
{
start();
write_byte(0xa0);
respons();
write_byte(address);
respons();
write_byte(date);
respons();
stop();
}
uchar read_add(uchar address)
{
uchar date;
start();
write_byte(0xa0);
respons();
write_byte(address);
respons();
start();
write_byte(0xa1);
respons();
date=read_byte();
stop();
return date;
}
void main()
{
init();
write_add(23,0xaa);
delay1(100);
P1=read_add(23);
while(1);
}
以上就是关于关于AT24C02芯片的两个问题全部的内容,包括:关于AT24C02芯片的两个问题、在板子上的24C02怎么写程序进去、51单片机 IIC总线 写24C02 问题 看程序 高分悬赏 错误原因。。。。。等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)