24c02读写程序(已通过测试),24C02 read / write process
关键字:24c02读写程序(已通过测试)
24c02读写程序(已通过测试)
24c02读写程序(已通过测试)#ifndef _24C02_H
#define _24C02_H
// 脚定义
sbit SCL = P3^7; //24c02 SCL
sbit SDA = P3^6; //24c02 SDA
// 功能函数
void x24c02_delay(char x)
{
int i;
for(i=0;i}
void x24c02_start()
{
SDA = 1;
SCL = 1;
SDA = 0;
SCL = 0;
}
void x24c02_stop()
{
SDA=0;
SCL=1;
SDA=1;
}
void x24c02_writex(char j)
{
char i,temp;
temp=j;
for (i=0;i<8;i++)
{
temp=temp<<1;
SCL=0;
SDA=CY;
SCL=1;
}
SCL=0;
SDA=1;
}
char x24c02_readx()
{
char i,j,k=0;
SCL=0;
SDA=1;
for (i=0;i<8;i++)
{
SCL=1;
if (SDA==1) j=1;
else j=0;
k=(k<<1)|j;
SCL=0;
}
return(k);
}
void x24c02_clock()
{
char i=0;
SCL=1;
while ((SDA==1)&&(i<255))i++;
SCL=0;
}
void x24c02_init()
{
SCL = 1;
SDA = 1;
}
char x24c02_read(char address)
{
char i;
x24c02_start();
x24c02_writex(0xa0);
x24c02_clock();
x24c02_writex(address);
x24c02_clock();
x24c02_start();
x24c02_writex(0xa1);
x24c02_clock();
i=x24c02_readx();
x24c02_stop();
x24c02_delay(10);
return(i);
}
void x24c02_write(char address, char info)
{
EA=0;
x24c02_start();
x24c02_writex(0xa0);
x24c02_clock();
x24c02_writex(address);
x24c02_clock();
x24c02_writex(info);
x24c02_clock();
x24c02_stop();
EA=1;
x24c02_delay(50);
}
void x24c02_writestr(char address, unsigned char *wdata, unsigned char wlen)
{
unsigned char k=0;
do
{
x24c02_write(address+k, *(wdata + k));
k++;
} while(k < wlen);
}
void x24c02_readstr(char address, unsigned char *rdata, unsigned char rlen)
{
unsigned char k=0;
do
{
rdata[k] = x24c02_read(address+k);
k++;
} while(k < rlen);
}
#endif
#define _24C02_H
// 脚定义
sbit SCL = P3^7; //24c02 SCL
sbit SDA = P3^6; //24c02 SDA
// 功能函数
void x24c02_delay(char x)
{
int i;
for(i=0;i
void x24c02_start()
{
SDA = 1;
SCL = 1;
SDA = 0;
SCL = 0;
}
void x24c02_stop()
{
SDA=0;
SCL=1;
SDA=1;
}
void x24c02_writex(char j)
{
char i,temp;
temp=j;
for (i=0;i<8;i++)
{
temp=temp<<1;
SCL=0;
SDA=CY;
SCL=1;
}
SCL=0;
SDA=1;
}
char x24c02_readx()
{
char i,j,k=0;
SCL=0;
SDA=1;
for (i=0;i<8;i++)
{
SCL=1;
if (SDA==1) j=1;
else j=0;
k=(k<<1)|j;
SCL=0;
}
return(k);
}
void x24c02_clock()
{
char i=0;
SCL=1;
while ((SDA==1)&&(i<255))i++;
SCL=0;
}
void x24c02_init()
{
SCL = 1;
SDA = 1;
}
char x24c02_read(char address)
{
char i;
x24c02_start();
x24c02_writex(0xa0);
x24c02_clock();
x24c02_writex(address);
x24c02_clock();
x24c02_start();
x24c02_writex(0xa1);
x24c02_clock();
i=x24c02_readx();
x24c02_stop();
x24c02_delay(10);
return(i);
}
void x24c02_write(char address, char info)
{
EA=0;
x24c02_start();
x24c02_writex(0xa0);
x24c02_clock();
x24c02_writex(address);
x24c02_clock();
x24c02_writex(info);
x24c02_clock();
x24c02_stop();
EA=1;
x24c02_delay(50);
}
void x24c02_writestr(char address, unsigned char *wdata, unsigned char wlen)
{
unsigned char k=0;
do
{
x24c02_write(address+k, *(wdata + k));
k++;
} while(k < wlen);
}
void x24c02_readstr(char address, unsigned char *rdata, unsigned char rlen)
{
unsigned char k=0;
do
{
rdata[k] = x24c02_read(address+k);
k++;
} while(k < rlen);
}
#endif
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
发布评论请先 登录
相关推荐
STM32F103用普通IO口驱动24C02,读写不正确的原因?
以下24C02的驱动好像不稳定,不更换24C02时,读写都正确,但是更换一个24C02,数据就读写不正确,在把之前的正常的
发表于 04-19 06:12
通过STM32F103的I2C读写24LC024,超过16个以后读回来的地址上的数不对是怎么回事?
通过STM32F103的I2C读写24LC024,现在问题是一次读写16个及以内的数据完全正常 ,超过16个以后读回来的地址上的数不对,想问
发表于 04-18 06:37
对24C02写或读数据的时候从机不回ACK是什么情况?
各位高手是否有碰到过对24C02写或读数据的时候从机不回ACK
就是我对24C02发送写数据0xa0或发读0xa0 但从机不回ACK信号那是什么情况?
发表于 10-18 06:30
AT24C04芯片驱动程序原理
1.芯片简介 24c02是一种串行电可擦除只读存储器(以下数据均以AT24C02为例),即eeprom存储器器件,采用的 IIC 总线技术。24c02在许多试验中都有出现。24c02
STM32 IIC读写AT24C02(三)
现在我们已经实现了AT24C02的单字节读写,但是对于对于2K内存来说,如果对全部数据的读取或者写入都只用单字节读写来完成,这样就会很不方便。
发表于 07-22 10:33
•542次阅读
STM32 IIC读写AT24C02(二)
上次已经完成了IIC读写AT24C02的协议层,现在开始编写读写AT24C02的驱动函数。先从单字节的读写开始。
发表于 07-22 10:31
•758次阅读
STM32单片机学习笔记(4):24C02(模拟IIC)
24C02的一个实例,IIC通信是一种比较典型的串行通信方式,在很多情况下都会有所使用,了解并熟悉IIC通信就显得十分重要。本项目之所以使用模拟IIC,而没有使用STM32单片机内置的硬件IIC,主要
发表于 07-19 15:34
•943次阅读
评论