资料介绍
基于CPLD的系统中I2C总线的设计
摘要: 在介绍I2C总线协议的基础上,讨论了基于CPLD的系统中I2C总线的设计技术,并结合工程实例设计了I2C总线IP核,给出了部分源代码和仿真结果。
关键词: I2C总线 IP核 CPLD
I2C总线是PHILIPS公司推出的新一代串行总线,其应用日渐广泛?1~2?。目前许多单片机都带有I2C总线接口,能方便地实现I2C总线设计;对没有I2C总线的微控制器(MCU),可以采用两条I/O口线进行模拟。在以单片机为MCU的系统中很容易实现I2C总线的模拟扩展,有现成的通用软件包可以使用?2~3?。
对有些基于CPLD的系统,要与带有I2C总线接口的外围器件连接,实现起来相对复杂一些。为实现系统中的I2C总线接口,可以另外引入单片机,也可以采用PCF8584或者PCA9564器件(PHILIPS公司推出的专用I2C总线扩展器)进行扩展,但这样会增加系统成本,使系统冗余复杂。像ALTERA、XILINX等一些大公司有专用的基于CPLD器件的I2C总线IP核,但这些IP核的通用性不强,需要的外围控制信号较多,占用系统很大的资源,因此直接采用这种IP核不可取。
I2C总线的协议
I2C总线仅仅依靠两根连线就实现了完善的全双工同步数据传送:一根为串行数据线(SDA),一根为串行时钟线(SCL)。该总线协议有严格的时序要求。总线工作时,由时钟控制线SCL传送时钟脉冲,由串行数据线SDA传送数据。总线传送的每帧数据均为一个字节(8 bit),但启动I2C总线后,传送的字节个数没有限制,只要求每传送一个字节后,对方回应一个应答位(Acknowledge Bit)。发送数据时首先发送数据的最高位(MSB)。
I2C总线协议规定,启动总线后第一个字节的高7位是从器件的寻址地址,第8位为方向位(“0”表示主器件对从器件的写操作;“1”表示主器件对从器件的读操作),其余的字节为操作的数据。总线每次传送开始时有起始信号,结束时有停止信号。在总线传送完一个或几个字节后,可以使SCL线的电平变低,从而使传送暂停。
图1列出了I2C总线上典型信号的时序,图2表示I2C总线上一次完整的数据传送过程。
依据I2C总线的传输协议,总线工作时的具体时序如下:
起始信号(S):在时钟SCL为高电平期间,数据线SDA出现由高电平向低电平的变化,用于启动I2C总线,准备开始传送数据;
停止信号(P):在时钟SCL为高电平期间,数据线SDA出现由低电平向高电平的变化,用于停止I2C总线上的数据传送;
应答信号(A):I2C总线的第9个脉冲对应应答位,若SDA线上显示低电平则为总线“应答”(A),若SDA线上显示高电平则为“非应答”(/A);
数据位传送:I2C总线起始信号或应答信号之后的第1~8个时钟脉冲对应一个字节的8位数据传送。在脉冲高电平期间,数据串行传送;在脉冲低电平期间,数据准备,允许总线上数据电平变化。
摘要: 在介绍I2C总线协议的基础上,讨论了基于CPLD的系统中I2C总线的设计技术,并结合工程实例设计了I2C总线IP核,给出了部分源代码和仿真结果。
关键词: I2C总线 IP核 CPLD
I2C总线是PHILIPS公司推出的新一代串行总线,其应用日渐广泛?1~2?。目前许多单片机都带有I2C总线接口,能方便地实现I2C总线设计;对没有I2C总线的微控制器(MCU),可以采用两条I/O口线进行模拟。在以单片机为MCU的系统中很容易实现I2C总线的模拟扩展,有现成的通用软件包可以使用?2~3?。
对有些基于CPLD的系统,要与带有I2C总线接口的外围器件连接,实现起来相对复杂一些。为实现系统中的I2C总线接口,可以另外引入单片机,也可以采用PCF8584或者PCA9564器件(PHILIPS公司推出的专用I2C总线扩展器)进行扩展,但这样会增加系统成本,使系统冗余复杂。像ALTERA、XILINX等一些大公司有专用的基于CPLD器件的I2C总线IP核,但这些IP核的通用性不强,需要的外围控制信号较多,占用系统很大的资源,因此直接采用这种IP核不可取。
I2C总线的协议
I2C总线仅仅依靠两根连线就实现了完善的全双工同步数据传送:一根为串行数据线(SDA),一根为串行时钟线(SCL)。该总线协议有严格的时序要求。总线工作时,由时钟控制线SCL传送时钟脉冲,由串行数据线SDA传送数据。总线传送的每帧数据均为一个字节(8 bit),但启动I2C总线后,传送的字节个数没有限制,只要求每传送一个字节后,对方回应一个应答位(Acknowledge Bit)。发送数据时首先发送数据的最高位(MSB)。
I2C总线协议规定,启动总线后第一个字节的高7位是从器件的寻址地址,第8位为方向位(“0”表示主器件对从器件的写操作;“1”表示主器件对从器件的读操作),其余的字节为操作的数据。总线每次传送开始时有起始信号,结束时有停止信号。在总线传送完一个或几个字节后,可以使SCL线的电平变低,从而使传送暂停。
图1列出了I2C总线上典型信号的时序,图2表示I2C总线上一次完整的数据传送过程。
依据I2C总线的传输协议,总线工作时的具体时序如下:
起始信号(S):在时钟SCL为高电平期间,数据线SDA出现由高电平向低电平的变化,用于启动I2C总线,准备开始传送数据;
停止信号(P):在时钟SCL为高电平期间,数据线SDA出现由低电平向高电平的变化,用于停止I2C总线上的数据传送;
应答信号(A):I2C总线的第9个脉冲对应应答位,若SDA线上显示低电平则为总线“应答”(A),若SDA线上显示高电平则为“非应答”(/A);
数据位传送:I2C总线起始信号或应答信号之后的第1~8个时钟脉冲对应一个字节的8位数据传送。在脉冲高电平期间,数据串行传送;在脉冲低电平期间,数据准备,允许总线上数据电平变化。
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- I2C总线应用系统设计运用 10次下载
- 基于51的I2c总线 34次下载
- SPI总线及I2C总线工作原理 0次下载
- 基于CPLD的I2C总线接口设计
- I2C总线在Linux系统中的驱动设计
- I2C总线技术在彩电中的应用
- 基于I2C总线的大型开关矩阵设计与实现
- I2C总线应用中的几个问题
- 基于MCU和CPLD系统中I2C总线控制器的设计与实现
- I2C总线规范与I2C器件C51读写程序
- i2c总线的特点
- 基于MCU 的I2C 总线传输设计
- 用嵌入式系统的SPI模块实现I2C总线通信
- i2c总线ppt(I2C总线器件应用) 0次下载
- I2C总线器件在高抗干扰系统中的应用 0次下载
- I2C总线协议的工作原理和寻址格式 1901次阅读
- Linux I2C驱动入门知识科普 1735次阅读
- i2c总线用来做什么_i2c总线数据传输过程 7305次阅读
- I2C总线驱动的C语言源程序详细说明 5263次阅读
- I2C总线系统中引起电压失常的原因和检修方法 1.6w次阅读
- I2C总线控制系统的构成_I2C总线控制系统的特点 1658次阅读
- 基于MCS-51单片机I2C总线接口电路的设计 3459次阅读
- I2C总线的工作原理解析 6719次阅读
- I2C总线的特点与构成详解 1w次阅读
- 80C51单片机模拟I2C总线的主机程序分享 3483次阅读
- I2C总线的特点、控制技术与传输分析 1w次阅读
- i2c总线相关知识 3568次阅读
- 《振南电子STM32视频教程》第八讲:I2C总线 1119次阅读
- 基于FPGA的I2C SLAVE模式总线的设计方案 1.3w次阅读
- I2C器件接口IP核的CPLD设计 1176次阅读
下载排行
本周
- 1RK3588数据手册
- 2.24 MB | 7次下载 | 免费
- 2台达变频器VFD-M使用手册
- 2.51 MB | 2次下载 | 免费
- 3DAP03变频器使用手册
- 5.72 MB | 2次下载 | 免费
- 4PC0310 高亮度恒流LED驱动控制电路数据手册
- 0.54 MB | 1次下载 | 免费
- 5SAJ8000变频器使用手册
- 1.37 MB | 1次下载 | 免费
- 6HSJ08 电机驱动芯片数据手册
- 1.00 MB | 次下载 | 免费
- 7超大量程数字电容表BK-820电路原理图资料
- 0.14 MB | 次下载 | 10 积分
- 8ZYNQ UltraScalePlus RFSOC QSPI Flash固化常见问题说明
- 1.31 MB | 次下载 | 免费
本月
- 1常用电子元器件集锦
- 1.72 MB | 24500次下载 | 免费
- 2如何看懂电子电路图
- 12.88 MB | 137次下载 | 免费
- 3PC2456高压浪涌抑制器控制器数据手册
- 3.03 MB | 14次下载 | 免费
- 4ssd1306单片 CMOS OLED/PLED 驱动芯片中文手册
- 1.66 MB | 11次下载 | 1 积分
- 5PC5502负载均流控制电路数据手册
- 1.63 MB | 11次下载 | 免费
- 6PC2464具理想二极管的浪涌抑制控制器数据手册
- 4.42 MB | 9次下载 | 免费
- 7PC2466高电压浪涌抑制器数据手册
- 3.37 MB | 8次下载 | 免费
- 8ESP32开发板元件资料
- 0.03 MB | 7次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935132次下载 | 10 积分
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420064次下载 | 10 积分
- 3Altium DXP2002下载入口
- 未知 | 233089次下载 | 10 积分
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191409次下载 | 10 积分
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183345次下载 | 10 积分
- 6labview8.5下载
- 未知 | 81593次下载 | 10 积分
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73818次下载 | 10 积分
- 8LabVIEW 8.6下载
- 未知 | 65990次下载 | 10 积分
电子发烧友App






创作
发文章
发帖
提问
发资料
发视频
上传资料赚积分
评论