欢迎来到天天文库
浏览记录
ID:15043307
大小:171.00 KB
页数:17页
时间:2018-08-01
《实验八 iic通信协议》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、实验八I2C通信协议一、实验目的:1、培养学生阅读资料的能力;2、加深学生对I2C总线通信协议的理解;3、加强学生对模块化编程的理解;二、实验环境:1、硬件环境:PC机一台、单片机实验板一块、母头串口交叉线、USB电源线;2、软件环境:keiluVision2集成开发环境;STC-ISP下载上位机软件;三、实验原理:要学会I2C通信协议的编程,关键是要看懂并掌握其时序图,理解对I2C通信协议相关子程序的实验编写。I2C通信协议的总线时序图如下所示:I2C总线时序图I2C相关子程序的详细介绍1、起始信号:SC
2、L为高电平时,SDA由高电平向低电平跳变,开始传送数据。2、结束信号:SCL为高电平时,SDA由低电平向高电平跳变,结束传送数据。起始信号和结束信号的时序图如下所示:起始信号和结束信号的时序图起始信号的流程如下:1、SCL和SDA拉高,保持时间约为0.6us-4us;2、拉低SDA,保持时间为约为0.6us-4us;3、拉低时钟线结束信号的流程如下:1、SCL置高电平,SDA置低电平,保持时间约为0.6us-4us2、SDA拉高,保持时间约为1.2-4us;应答信号:接收数据的IC在接收到8bit数据后,向
3、发送数据的IC发出特定的低电平脉冲,表示已收到数据。CPU向受控单元发出一个信号后,等待受控单元发出一个应答信号,CPU接收到应答信号后,根据实际情况作出是否继续传递信号的判断。若未收到应答信号,由判断为受控单元出现故障。应答信号的时序图如下所示:应答时序图发送时的应答信号;**********应答信号**********ACK:SETBSDA;数据线置高SETBSCL;时钟线置高ACALLDELAYJBSDA,$;等待数据线变低ACALLDELAYCLRSCL;时钟线置低RET注意:这里如果数据线一直为高
4、将进入死循环,所以一般我们都会在这做一个容错的处理。具体的程序如下:ACK:MOVR4,#00HSETBSDASETBSCLLOP0:JNBSDA,LOPDJNZR4,LOP0;循环255次LOP:ACALLDELCLRSCLRET接收时的应答信号ACK1:CLRSDA;数据线置低SETBSCL;时钟线置高NOPNOPCLRSCL;时钟线置低SETBSDA;数据线置高RET1、字节的发送和接收写周期时序图一字节数据发送子程序,流程如下:开始时钟线置低累加器左移一位数据传送时钟线置高一个应答信号周期结束8位信
5、号完否?YN图6-22发送子程序流程图(2)一字节数据接收子程序,流程如下:开始数据线置高时钟线置高数据传送累加器左移一位时钟线置低结束8位信号完否YN图6-23接收子程序流程图7、写操作(1)字节写图6-24字节写时序图流程如下:写器件命令应答信号器件地址应答信号数据地址应答信号停止信号延时结束开始信号图6-25字节写的流程图(2)页写图6-26页写时序图页写流程如下:写器件命令应答信号器件地址应答信号数据地址应答信号停止信号开始信号写数据字节初值数据地址-1数据写完否?YN7图6-27页写流程图8、读操
6、作(1)选择读图6-28选择读时序图图6-29NOACK时序图(2)连续读图6-30连续读时序图三、实验原理图:I2C总线电路图四、实验例题:例题一编写一程序,实现I2C的指定字节读写,用24C08来记录单片机复位或者开机的次数,并将复位或者开机的次数显示在数码管上。程序分析本程序利用单片机复位时程序总是从0000H开始执行的特性。用24C08的一个单元来存储开机的次数,程序一开始就将次数读出来,加上本次的开机,显示在数码管上。再将加1之后的数据存入24c08的对应单元。程序代码;*************
7、*************************************************************;****程序功能:实现对24C08的字节读写,用24C08记录开机次数,显示在数码管上;****程序编写:李代勇;****编写日期:2007/2/04;**************************************************************************;*******************************************
8、*******************************;初始化数据设置;**************************************************************************SDAEQUP1.7;定义数据线为P1.7(实验板上已固定,不可更改)SCLEQUP1.6;定义始终线为P1.6I2C_AddrEQU10H;定义地址缓冲区,存储要读写24C08的单元地址
此文档下载收益归作者所有