分享

I2C总线AT24C02芯片应用

 共同成长888 2015-07-18

  I2C总线进行数据传送时,时钟信号为高电平期间,数据线上的数据必须保持稳定,只有在时钟线上的信号为低电平期间,数据线上的高电平或低电平状态才允许变化。

    
    

       


起始和终止信号
 SCL线为高电平期间,SDA线由高电平向低电平的变化表示起始信号;SCL线为高电平期间,SDA线由低电平向高电平的变化表示终止信号。

数据传送格式1)字节传送与应答

每一个字节必须保证是8位长度。数据传送时,先传送最高位(MSB),每一个被传送的字节后面都必须跟随一位应答位(即一帧共有9位)。如果一段时间内没有收到从机的应答信号,则自动认为从机已正确接收到数据。
3引角对应,为当前电路中的地址选择线,三根线可选择8个芯片同时连接在电路中,当要与哪个芯片通信时传送相应的地址即可与该芯片建立连接,TX-1B实验板上三根地址线都为0。最后一位R/W为告诉从机下一字节数据是要读还是写,0为写入,1为读出。 

 


    AT24C02
的芯片地址如下图,1010为固定,A0A1A2正好与芯片的12




code:


 

 

/*
通讯中 SDA 口通讯双方都可为输出,如果一方输出低,

另一方则如果输出高也不能使SDA为高,相当于,输出低的一方占住了SDA口。

两个口,一个出高一个出低,则线上电平是低的。

这是由于,出高的驱动能力不及出低拉电流的能力。


所以SDA=1为释放数据线
*/

 

 

 


 

#include<reg52.h>

#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系统呢有点民主成分,从机可以向主机传信息,既发1,形象的成为“1”:咦 你们小麻虾 小老百信还要上方发信息呀??!! 事实上是的 0为下蛋-----下传数据;1为上访-----上传数据。记住了吧!

时钟为高SCL=1时 数据那得稳定 俗称维稳期间当然 时钟撤了 SCL=0时 随便你虾子变化数据。

发送启动信号 那得我们主机发了 党外人士没这个权利 在时钟为高 警察在的时 本地图片,请重新上传候 主机发一个下跳沿信号 表示开会了 开始了既:SCL=1时 SDA   你们老百姓就等着查户口吧!

当官的在警察在时下跳了 于是衙门发令查户口 高七位为你我家庭住址,最低一位为数据方向 上面已表在此老子不说了。

各民众,自己根据收到的地址码对号入座,发现是自己 那就准备收吧---数据。

而且在收数据时 每次收到了 都得回答“诺”.若是犯人那得点头说“政府好”,当然主机可以不回答 主机不回答视为停止传数据的命令 注意了 每次回答都必须是时钟为高时拉数据线为低哦!不得有误。

主机若在时钟为高时上跳---警察在的时候领导跳上台那是表示结束了gameover了 数据传送动作停止了。

2,单片机模拟I2C总线通信

目前很多单片机都有硬硬的I2C总线通信控制单元,工作时无需我们介入自动工作,但可怜的51单片机没有 这个接口我们不得不通过软件模拟I2C总线的工作时序,在要用时。调用这些子函数即可。

有仨方式:一,主机向从机发数据,数据传送方向在整个过程中不变。

         二,主机在第一个字节后,立即从从机读数。
三,在传送过程中,当需要改变传送方向时,需将起始信号和从机地址重复发放一次,而两次读写方向的那个位刚好相反。


 

 


    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多