{
sda=1;
delay();
scl=1;
delay();
sda=0;
delay();
}
应答信号:每传送一个字节数据,都要有接收设备产生应答信号。在SCL为高电平期间,接收设备将SDA拉为低电平表示数据传输正确。
{
uchar i;
scl=1;
delay();
while((sda==1)&&(i<250))i++;
scl=0;
delay();
}
停止信号:在全部数据发送完毕后,主机发送停止信号。即在SCL为高电平期间,SDA上产生一个上升沿信号。
停止信号:
void stop() //终止信号
{
sda=0;
delay();
scl=1;
delay();
sda=1;
delay();
}
IIC总线初始化
void init() //初始化
{
sda=1;
delay();
scl=1;
delay();
}
根据IIC总线写数据函数:
void write_byte(uchar date) //写数据函数
{
uchar i,temp;
temp=date;
for(i=0;i<8;i++)
{
temp=temp<<1;//将数据左移一位,最高位移至CY
scl=0;
delay();
sda=CY;
delay();
scl=1;
delay();
}
scl=0;
delay();
sda=1;
delay();
}
根据IIC读数据函数
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; //或运算,sda为0或者1,放到了k的最低位了,因k最低位为0
scl=0;
delay();
}
return k; //即为读到的数据
}
在某寄存器上写数据
void write_add(uchar address,uchar date) //在某地址上写数据
{
start(); //起始信号
write_byte(0xa0); //发送器件地址,最低位为0,表示主机发送
respons(); //应答
write_byte(address);//发送某器件存储单元地址
respons(); //应答
write_byte(date); //写数据
respons(); //应答
stop(); //停止
}
其中a0表示主机固定地址。
在模寄存器上读数据
uchar read_add(uchar address) //在某地址上读数据
{
uchar date;
start(); //起始信号
write_byte(0xa0); //发送器件地址,最低位为0,表示主机发送
respons(); //应答
write_byte(address);//发送某器件存储单元地址,表示要读此位置的数据
respons(); //应答
start(); //起始
write_byte(0xa1);//发送器件地址,最低位为1,表示主机接受数据
respons();
date=read_byte();
stop();
return date;
}
上一篇:基于CAN总线的车灯设计
下一篇:MCGS组态软件在DCS总线接口中的应用
推荐阅读最新更新时间:2024-05-02 23:52
DA转换(IIC总线)
项目描述 向PCF8591芯片的AN2通道输入一个电压模拟量,经过AD转换后,单片机通过IIC总线读取转换后的数据,并将其量化后实时显示在LCD上。然后将AD转换后的数据写入PCF8591中进行DA转换,并用LED灯的亮度来显示模拟量的大小。 仿真原理图如下: C语言代码如下: /*------------------------ FileName: DAC.h Function: 头文件 Author: Zhang Kaizhou Date: 2019-6-13 17:12:49 ------------------------*/ #include reg52.h #include intrins.h #inclu
[单片机]
DS1302读写程序(IIC总线)
#include reg51.h //包含单片机寄存器的头文件 #include intrins.h //包含_nop_()函数定义的头文件 #define uchar unsigned char #define uint unsigned int sbit SRT=P3^5; sbit IO=P3^4; sbit SCK=P3^6; uchar code table ={0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71}; uchar miao,fen,shi,tian,
[单片机]
通用光伏系统测试平台的设计
光伏系统是利用太阳电池组件和其他辅助设备将太阳能转换成电能并进行一定应用的系统。近来,各种新型的光伏系统被不断设计投产。为优化和提高系统性能和稳定性,工程师在设计这些系统的过程中需要额外设计系统测试方案对其性能和实际运行效果进行测试,如采集和记录充放电效率、运行功率、实时太阳能电池板功率等数据。不同的工程师在设计系统时若采用不同的数据测试方案,这将可能会导致项目管理混乱和引起不必要的重复设计,而实际上光伏应用系统有着许多的共性,测试过程中所需要的参数具有一定的重复性,因此可以设计一种具有一定扩展能力的通用光伏系统测试平台,测试常用光伏系统参数并兼容一些额外的参数和计算,以简化和统一测试标准,缩短系统设计周期。 1 系统基本结
[测试测量]
rs485通信协议
RS485主从式多机通讯协议 一、数据传输协议
此协议定义了一个控制器能认识使用的消息结构,而不管它们是经过何种网络进行通信的。它描述了一控制器请求访问其它设备的过程,如何回应来自其它设备的请求,以及怎样侦测错误并记录。它制定了消息域格局和内容的公共格式。
此协议决定了每个控制器须要知道它们的设备地址,识别按地址发来的消息,决定要产生何种行动。如果需要回应,控制器将生成反馈信息按本协议发出。
1、数据在网络上转输
控制器通信使用主—从技术,即仅一设备(主设备)能初始化传输(查询)。其它设备(从设备)根据主设备查询提供的数据作出相应反应。
主设备可单独和从设备通信,也能以广播方式和所有从设备通信。如果单独通信,从设
[嵌入式]
C51单片机IIC总线通信协议及简单应用例程
首先我们要分清通信协议和通讯协议中的信和讯的含义 “通信”仅指数据通信,即通过计算机网络系统和数据通信系统实现数据的端到端传输。 通信的“信”指的是信息(Information),信息的载体是二进制的数据,数据则是可以用来表达传统媒体形式的信息,如声音、图像、动画等。 “通信”重在传输手段或使用方式,从这个角度,“通信”的概念包括了信息“传输”。 因此通信协议主要集中在ISO七层协议中的物理层、数据链路层、网络层和传输层。 先简单的说明以下I2C总线, I2C总线是一种串行数据总线,只有二根信号线,一根是双向的数据线SDA,另一根是时钟线SCL。 处理器和芯片间的通信可以形象的比喻成两个人讲话:1、你说的别人得能听懂:双方
[单片机]
51单片机普通IO口模拟IIC总线的程序实现
IIC是由Philips公司发明的一种串行数据通信协议,仅使用两根信号线:SerialClock(简称SCL)和SerialData(简称SDA)。 IIC是总线结构,1个Master,1个或多个Slave,各Slave设备以7位地址区分,地址后面再跟1位读写位,表示读(=1)或者写(=0),所以我们有时也可看到8位形式的设备地址,此时每个设备有读、写两个地址,高7位地址其实是相同的。 IIC数据格式如下: 无数据:SCL=1,SDA=1; 开始位(Start):当SCL=1时,SDA由1向0跳变; 停止位(Stop):当SCL=1时,SDA由0向1跳变; 数据位:当SCL由0向1跳变时,由发送方控制SDA,此时SDA为有效数据,不
[单片机]
一种实现RS 422通信协议的接口电路
目前通用的串行通信接口标准主要有RS 232,RS 422和RS 485,其中RS 232属于单端不平衡传输协议,传输距离短,抗干扰性差;RS 485与RS 422均为平衡通信接口,但RS 485他只有一对双绞线,工作于半双工模式。RS 422属于一种平衡通信接口,采用全双工通信模式,传输速率高达10 Mb/s,传输距离长2 000 m,并允许在一条平衡总线上连接最多10个接收器 。由于该类电路的优异性能,RS 422接口芯片已广泛应用于工业控制、仪器、仪表、多媒体网络、机电一体化产品等诸多领域。
1 系统概述
RS 422通信接口芯片系统框图如图1所示,主要包含数据发送模块和接收模块。接收模块主要是将通信总线差分电
[嵌入式]
美高森美LiteFast串行通信协议减少客户设计工作和上市时间
致力于在功耗、安全、可靠性和性能方面提供差异化半导体技术方案的领先供应商美高森美公司(Microsemi Corporation,纽约纳斯达克交易所代号:MSCC)宣布提供全新LiteFast解决方案,这是一项专有的轻量、高速、低迟滞、点至点串行通信协议。涵盖多种应用领域的嵌入式系统使用高速串行接口和协议来实现超过1Gbps速率传送数据。LiteFast充分利用SmartFusion 2系统级芯片(SoC)现场可编程逻辑器件(FPGA)、IGLOO 2 FPGA和RTG4 高速信号处理耐辐射FPGA器件中的串行器/解串器(SerDes)收发器模块,简便实施高速串行链接,推动客户减少设计工作和上市时间,而且无需重度的逻辑利用率,极大地
[嵌入式]