0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

I²C总线的验证及实现

星星科技指导员 来源:ADI 作者:ADI 2023-06-12 16:16 次阅读

80年代初期,Philips Semiconductor为减少电子产品内部并行数据总线的数量,开发了Inter IC (I²C)总线。1992年,Philips®发布I²C总线的1.0版本,该版本定义了一个2线、双向总线,用于IC之间的互联。到1998年为止,I²C总线已经成为低速IC互联的标准,50家以上的公司使用了该标准,I²C接口被集成在1000多种不同的IC内。

实验表明,本文提供的I²C总线配置很容易实现总线上从器件的访问。

背景及讨论

I²C总线能够工作在标准模式、快速模式或高速模式(Hs)。最大速率分别为100kbps (标准模式)、400kbps (快速模式)、1.7Mbps (Hs模式,Cb = 400pF)和3.4Mbps (Hs模式,Cb = 100pF)。

原标准模式采用7位地址,允许112个从地址。随着对从设备数量需求的增加,I²C总线引入了10位地址长度。

快速模式下,从设备增加了很多有用功能。最大数据速率提高四倍,增加到400kbps。快速模式下I²C总线还向下兼容,支持速率其它类似的常常连接到I²C总线的总线,例如,一些无法支持高速率的总线。为抑制噪声,快速模式器件的输入采用了施密特触发器结构;另外还要求I²C从器件在电源掉电时,其SCL和SDA为高阻态。

构建Hs模式的主要目的是提高数据通信速率—数据速率是标准模式的36倍。I²C总线工作在Hs模式时,最主要的影响是SCL线上从低电平到高电平的瞬变;因为标准模式和快速模式下,总线的上拉电阻不能产生较快的上升时间,以支持Hs模式的规格要求。绝大多数Hs模式系统必须在SCL线上提供有源上拉。其它改变包括:Hs模式的兼容性要求,Hs模式主机在标准、快速模式下使用的是8位代码。如果非应答(I²C帧结构的其中1位)在主机代码之后立即保持在高电平,那么在停止位出现之前所有通信都将保持在Hs模式。图1波形演示了如何使用主机代码进入Hs模式。

wKgaomSG1FGAJhPQAAAOIrKq3t8191.gif

图1. 从快速、标准I²C模式进入Hs模式的波形

内置I²C接口实例

PIC18F442微控制器(µC)包含I²C外设接口,此接口支持标准和快速I²C模式。图2给出一个应用电路,通过此接口接收来自ADC (MAX1169)的采样数据。PIC®收到数据后会以115k波特率的速率通过UART发送出去,数据经过RS-232收发器(MAX3232E)后由计算机标准串口采集。文件I2C_on_chip_asm.zip"包括了所有实现快速模式下PIC片上I²C接口通信的汇编程序。可以使用MPLAB IDE 6.10.00版本开发图2电路的汇编程序。

wKgZomSG1FKAEiCfAAB87zaKMeg028.gif

图2. PIC18F442 µC内置I²C接口与16位ADC (MAX1169)的连接

逐位仿真实现I²C通信

MAXQ2000是低功耗16位RISC µC,能够以逐位仿真方式实现标准模式、快速模式甚至1.7MHz Hs模式的I²C通信。图3给出了MAXQ2000的通用原理图,可以作为I²C主机支持三种工作模式。为了支持1.7MHz Hs模式,原理图中I²C总线采用有源上拉。I2C_bit_bang_asm.zip"文件包含了使用µC GPIO口仿真标准、快速模式I²C通信所需的所有汇编程序。

wKgaomSG1FSAFPX1AACAJCcejKc698.gif

图3. 该原理图(基于MAXQ2000低功耗LCD µC)提供了一个能够工作在标准、快速或Hs模式的I²C主机

MAXQ2000的I²C 固件的默认时钟速率为100kHz,但µC的16MHz系统时钟能够支持逐位仿真的I²C接口工作在400kHz。以下例程演示了捕获中断事件并在简单中断服务程序中处理中断的过程。开发工具使用MAX-IDE 1.0版(开发日期:2004年11月18日),该软件可从Maxim网站免费下载

I2C_bit_bang_c.zip"文件中包含了使用MAXQ2000 GPIO口逐位仿真标准、快速模式I²C通信所需的C程序源文件。图3对应的例程基于maxqi2c库文件,包括maxqi2c.h和maxqi2c.c.两个文件。将文件加载到用户工程后,可以在任何GPIO口支持100kHz或400kHz的I²C通信。但是,使用C程序产生特定速率的I²C通信时,图3中的Y1必须用20MHz晶体代替15MHz的晶体。本例使用了为MAXQ2000 1.12B版(FAE版)开发的IAR Embedded Workbench® IDE工具,用户可以在IAR网站注册后免费下载用于MAXQ2000的IAR Embedded Workbench (4K,初级版)。

HSI2C_bit_bang_asm_c.zip"文件包含了使用MAXQ2000 GPIO逐位仿真1.7MHz Hs模式I²C通信所需的汇编程序和C程序。源代码采用汇编语言和C语言混合代码,以便充分发挥这两种编程语言的优势。汇编程序有助于优化速度,C程序能够使源代码更简捷(只需少数几行指令)。Hs模式对时序要求非常苛刻,I²C接收函数(hsi2cRecv)采用了汇编程序,代码在hsi2c.asm文件内。

主程序C代码对MAXQ2000的UART进行初始化,波特率为115.2kbps。为了实现1.7MHz Hs模式I²C通信,图3中的Y1必须采用20MHz晶体。主程序C代码在需要时调用hsi2cRecv函数,并使用printf函数通过片上UART发送数据,数据格式为8-N-1。这里使用Rowley CrossWorks IDE 1.0版(Build 2 Licensed copy)开发工具。要想获得CrossWorks IDE工具,请联系Rowley Associates Limited或访问其网站。

I²C IP核外设接口的实现

DI2CM I²C IP核(由Digital Core Design开发)广泛用于许多CPLDFPGA器件。DI2CM I²C IP核将并行接口转换为I²C接口,并可支持主机真正工作在3.4MHz的Hs模式。图4应用电路中,Altera® EPM3256AQC208-10 CPLD包含DI2CM IP核。此电路需要使用40MHz晶体(U3)以支持1.7MHz和3.4MHz的Hs模式。带有输出使能的3态逻辑缓冲器使DI2CM IP核可以在SCL线上产生有源上拉,以满足Hs模式下I²C通信的要求。逻辑反相门电路U5、U6和U7用于实现高电平有效和低电平有效的内存映射的并行接口。

wKgZomSG1FaAV-bmAADRz74GmVA898.gif

图4. 按照电路所示配置,Altera EPM3256AQC208-10 CPLD中的DI2CM IP核能够实现Hs模式的I²C主机

HSI2C_IP_core_asm.zip"文件包含了所用用于实现Hs模式I²C通信所需的汇编程序,通过连接68HC16的存储器映射并行接口和使用DI2CM IP核编程的Altera EPM3256 CPLD实现。本例采用了Motorola® 68HC宏汇编程序,4.1版。

结论

由于I²C总线是目前业内使用最为广泛的串行总线,系统设计人员能够得到丰富的经过验证的例程。实施方案有—芯片内置、逐位仿真或IP核,具体取决于所使用的系统处理器。使用经过验证的设计示例进行开发时最简捷的途径,本文给出了三种工作模式下I²C接口的设计参考。

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    455

    文章

    50771

    浏览量

    423412
  • ADC
    ADC
    +关注

    关注

    0

    文章

    110

    浏览量

    16845
  • I²C总线
    +关注

    关注

    0

    文章

    14

    浏览量

    2127
收藏 人收藏

    评论

    相关推荐

    GPIO模拟I2C总线的驱动设计与实现

    I2C总线简单方便,是我们经常使用的一种总线。但有时候我们的MCU没有足够多的I2C控制器来实现我们的应用,所幸我可以使用普通的GPIO引脚
    发表于 12-14 14:19 5387次阅读
    GPIO模拟<b class='flag-5'>I2C</b><b class='flag-5'>总线</b>的驱动设计与<b class='flag-5'>实现</b>

    i2c总线ppt(I2C总线器件应用)

    I2C总线器件应用第一节 I2C总线器件应用概述I2C总线工作原理
    发表于 08-13 17:34 0次下载

    用Verilog HDL实现I2C总线功能

    简述了I2C总线的特点;介绍了开发FPGA时I2C总线模块的设计思想;给出并解释了用Verilog HDL实现部分
    发表于 10-19 10:49 104次下载

    什么是i2c总线

    什么是i2c总线  下载请点击: i2c总线协议中文版 
    发表于 11-05 09:26 2921次阅读

    总线I2C总线结合实现数字温度计实验

    总线I2C 总线结合实现数字温度计实验 一. 实验目的通过本实验,理解掌握单总线器件和
    发表于 09-22 17:42 3159次阅读
    单<b class='flag-5'>总线</b>和<b class='flag-5'>I2C</b><b class='flag-5'>总线</b>结合<b class='flag-5'>实现</b>数字温度计实验

    I2C总线驱动程序的实现

    I2C总线驱动程序的实现 I2C 驱动程序的简介本驱动程序为标准的51 系列CPU 编写,让CPU 模拟成一个I2C
    发表于 09-26 17:25 5747次阅读
    <b class='flag-5'>I2C</b><b class='flag-5'>总线</b>驱动程序的<b class='flag-5'>实现</b>

    I²C总线验证实现--Proven Imple

    I²C总线验证实现--Proven Implementations of the I
    发表于 01-22 16:16 2145次阅读
    <b class='flag-5'>I</b>²<b class='flag-5'>C</b><b class='flag-5'>总线</b>的<b class='flag-5'>验证</b>及<b class='flag-5'>实现</b>--Proven Imple

    IC总线验证实现

    摘要:本应用笔记简I²C总线验证实现单回顾了I²
    发表于 04-23 15:59 1854次阅读
    IC<b class='flag-5'>总线</b>的<b class='flag-5'>验证</b>及<b class='flag-5'>实现</b>

    IC总线验证实现

    摘要:本应用笔记简I²C总线验证实现单回顾了I²
    发表于 04-28 10:09 988次阅读
    IC<b class='flag-5'>总线</b>的<b class='flag-5'>验证</b>及<b class='flag-5'>实现</b>

    用Verilog HDL实现I2C总线功能

    摘要: 简述了I2C总线的特点;介绍了开发FPGA时I2C总线模块的设计思想;给出并解释了用Verilog HDL实现部分
    发表于 06-20 13:17 6893次阅读
    用Verilog HDL<b class='flag-5'>实现</b><b class='flag-5'>I2C</b><b class='flag-5'>总线</b>功能

    I2C总线的单片机C语言实现及其应用

    I2C总线的单片机C语言实现及其应用 本文介绍了I2C总线的概念、接口特性和传输时序,提出了一
    发表于 10-17 08:36 2972次阅读
    <b class='flag-5'>I2C</b><b class='flag-5'>总线</b>的单片机<b class='flag-5'>C</b>语言<b class='flag-5'>实现</b>及其应用

    基于CPLD的I2C总线接口设计

    在电路设计中,I2C总线是比较常用的两线式串行通信方式,大多数的CPU都擅长于并口操作,不具备直接操作I2C总线接口的能力。为了使不具备I2C
    发表于 02-12 16:11 95次下载
    基于CPLD的<b class='flag-5'>I2C</b><b class='flag-5'>总线</b>接口设计

    NIOS实现I2C总线

    I2C 总线实现关键是SDA,他是双向线,如果对与一个芯片只写而不读,I2C 实现起来很容易.使用NIOS
    发表于 11-01 14:28 38次下载

    基于SystemVerilog的I2C总线模块验证

    文中分析了基于Systemverilog验证环境的结构,并在介绍I 2 C总线协议的基础上,重点论述了验证环境中事务产生器及驱动器的设计。
    发表于 12-22 17:20 27次下载
    基于SystemVerilog的<b class='flag-5'>I2C</b><b class='flag-5'>总线</b>模块<b class='flag-5'>验证</b>

    软件模拟I2C总线C51实现

    软件模拟I2C总线C51实现
    发表于 10-13 11:03 8次下载
    软件模拟<b class='flag-5'>I2C</b><b class='flag-5'>总线</b>的<b class='flag-5'>C</b>51<b class='flag-5'>实现</b>