I2C总线AT24C02芯片应用
起始和终止信号:SCL线为高电平期间,SDA线由高电平向低电平的变化表示起始信号;SCL线为高电平期间,SDA线由低电平向高电平的变化表示终止信号。
数据传送格式(1)字节传送与应答
每一个字节必须保证是8位长度。数据传送时,先传送最高位(MSB),每一个被传送的字节后面都必须跟随一位应答位(即一帧共有9位)。如果一段时间内没有收到从机的应答信号,则自动认为从机已正确接收到数据。
3引角对应,为当前电路中的地址选择线,三根线可选择8个芯片同时连接在电路中,当要与哪个芯片通信时传送相应的地址即可与该芯片建立连接,TX-1B实验板上三根地址线都为0。最后一位R/W为告诉从机下一字节数据是要读还是写,0为写入,1为读出。
AT24C02的芯片地址如下图,1010为固定,A0,A1,A2正好与芯片的1,2,
code:
/*
通讯中 SDA 口通讯双方都可为输出,如果一方输出低,
另一方则如果输出高也不能使SDA为高,相当于,输出低的一方占住了SDA口。
两个口,一个出高一个出低,则线上电平是低的。
这是由于,出高的驱动能力不及出低拉电流的能力。
所以SDA=1为释放数据线
*/
#include
#define uint unsigned int
#define uchar unsigned char
sbit sda=P2^0;
sbit scl=P2^1;
void delay()//执行空语句,微秒级延时函数
{;;}
void delay1ms(uint z)//延时1ms
{
uint x,y;
for(x=z;x>0;x--)
{
for(y=0;y<=110;y++)
{
}
}
}
void init()//初始化状态下SCL和SDA都为高电平
{
scl=1;
delay();
sda=1;
delay();
}
void start()//在SCL为高电平时SDA由高电平到低电平
{
sda=1;
delay();
scl=1;
delay();
sda=0;
}
void respons()
/*
应答信号,SCL在高电平期间,SDA被从设备拉为低电平表示应答。
(sda==1)和i<255相与,表示若在一段时间内没有从器件的应答则主器件
默认从器件已经收到数据而不再等待应答信号
*/
{
uchar i;
scl=1;
delay();
while((sda==1)&&(i<250))
{
i++;
}
scl=0;
delay();
}
void stop()//SCL在高电平期间,SDA一个上升沿停止信号
{
sda=0;
delay();
scl=1;
delay();
sda=1;
}
void write_byte(uchar date)//写一个字节
{
uchar i,temp;
temp=date;
for(i=0;i<8;i++)
{
temp=temp<1;
scl=0;//只有在SCL为0期间才允许SDA数据线上的状态才允许变化
delay();
sda=CY;//PSW的寄存器的CY进位标志位
delay();
scl=1; //SCL时钟信号为高电平期间数据线上的数据必须保持稳定
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();
}
//delay();here is a bug
return k;
}
void write_address(uchar address,uchar date)
{
start();
write_byte(0xa0);
respons();
write_byte(address);
respons();
write_byte(date);
respons();
stop();
}
uchar read_address(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_address(1,0xfe);
delay1ms(100);
P2=read_address(1);
while(1);
}
I2C总线介绍:
I2C总线(Inter IC Bus)由飞利浦公司推出,是近年来微电子控制领域广泛采用的一宗新型总线标准,它使同步通信的一种特殊形式,具有接口少、控制简单、器件封装形体小、通信速率较高等优点(可达400Kbps)。在主从通信中,可以有多个I2C总线器件同时接到I2C总线上,所有与I2C总线兼容的器件都具有标准的接口,通过地址来识别通信对象,是她可以经由I2C总线相互直接通信。
I2C总线由数据线和时钟线SDA和SCL两条线构成,可发送数据可接收数据。于CPU及被控IC间、IC与IC间均可双向传送,各器件均并于总线上,各自有唯一地址。信息传输中,I2C总线上的各器件既是被控又是控制器件,既是发送器又是接收器。CPU发出的控制信号分为地址码和数据吗两部分;地址码选址;数据吗送数。故而各IC虽同并于总线上但却各自独立。
I2C总线硬件结构图
图中:ACL时钟,SDA数据 接上拉电阻,故总线空闲是高电平,任一器件变低均将拉低电平故曰:各器件的时钟线及数据线乃“与”关系。
通信格式为 时钟高时下跳开始寻地址 发送一字节 8位中低位为数据方向 0为我党要向下面发指令 形象的为“O”,俗称为蛋,如川蛋:“川O001”,陕蛋:“陕O001”都是当官的向下发指令,发飙的,当然,单片机哎平方C系统呢有点民主成分,从机可以向主机传信息,既
I2C总线AT24C02芯 相关文章:
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)
- Windows CE 进程、线程和内存管理(二)(11-09)