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

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

3天内不再提示

基于FPGA的I2C通信协议设计

友晶FPGA 来源:友晶FPGA 2025-12-26 09:44 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

1 I2C简介

I2C(Inter-Integrated Circuit)是一种由飞利浦半导体(现为恩智浦半导体)在1980年代初开发的同步、串行、半双工的总线型通信协议。主要用于近距离(同一块印刷电路板(PCB)上的集成电路(IC)之间)、低速(注:标准模式100K,快速模式400K,高速模式3.4M)的芯片之间的通信。

I2C总线有两根信号线,一根数据线SDA用于收发数据,一根时钟线SCL用于通信双方时钟的同步。I2C总线是一种多主机总线,连接在I2C总线上的器件分为主机和从机,主机有权发起和结束一次通信,而从机只能被主机呼叫。每个连接到I2C总线上的器件都有一个唯一的地址(7-bit)。主机通过I2C设备的地址来选择从机。

97eb9964-dae8-11f0-8c8f-92fbcf53809c.png

2 I2C的三态门电路

信息双向传输(方向为inout)的时候需要使用三态门电路。FPGA内部三态门结构:

984718e8-dae8-11f0-8c8f-92fbcf53809c.png

当sda_out为1时,sda被设置为高阻态(1'bz),即此时sda由外部设备(或上拉电阻)控制。当sda_out为0时,sda被驱动为0。这种设计符合I2C协议的开漏输出特性:I2C设备只能将数据线拉低(输出0)或释放(输出高阻,由上拉电阻拉高)。因此,这个三态设置实现了I2C数据线的双向通信:既可以输出数据(拉低),也可以输入数据(释放总线并读取)。具体的Verilog实现如下:

989c7edc-dae8-11f0-8c8f-92fbcf53809c.png

所以FPGA和外设之间要有个上拉电阻,如下是DE10-Nano的相关电路图:

98f0b182-dae8-11f0-8c8f-92fbcf53809c.png

3 I2C协议的开始与结束信号

开始条件为当SCLK(时钟脚)保持在高电平时, SDIN(数据脚)从高到低,接着会开始进行地址与数据传输;停止的条件是被定义成在 SCLK 在高电平时, SDIN 有一个低到高转换:

99446d54-dae8-11f0-8c8f-92fbcf53809c.png

4 I2C协议的字节传送与应答

I2C总线通信时每个字节为8位长度,数据传送时,先传送最高位,后传送低位,发送器发送完一个字节数据后,接收器必须发送1位应答位(应答:低电平"0";非应答:没接收到数据或者接收器不想应答,就保持高电平"1")来回应发送器,即一帧共有9位。

9997e9d4-dae8-11f0-8c8f-92fbcf53809c.png

5 I2C协议的同步信号

I2C总线在进行数据传送时:

时钟线SCL为低电平时,发送器向数据线上发送1-bit数据,在此期间数据线上的信号允许变化;

时钟线SCL为高电平时,接收器从数据线上读取1-bit数据,在此期间数据线上的信号不允许发生变化,必须保持稳定。

99edb562-dae8-11f0-8c8f-92fbcf53809c.png

6 I2C协议的写操作

主机先产生一个起始信号ST,再由主机发送出欲控制的器件地址Device Address[6:0],再加上 1 位的 W/R 读写位(设定为 0)。从机收到主机发送出8 位信号后,会回应一个 ACK 信号;接着送出寄存器地址Register Address[7:0](有的寄存器地址是16位,则可分两次发送),从机收到主机发送出8 位信号后,会回应一个 ACK 信号;接着送出 8 位数据 Data[7:0],从机收到主机发送出8 位信号后,会回应一个ACK 信号。传输完成后,会从主机送出停止信号SP。则完成了将数据 Data[7:0] 写入 Device Address[6:0] 设备中的 Register Address[7:0] 寄存器中:

9a43e5cc-dae8-11f0-8c8f-92fbcf53809c.png

7 I2C协议的读操作

主机先产生一个起始信号ST,再由主机发送出欲控制的器件地址Device Address[6:0],再加上 1 位的 W/R 读写位(设定为 0)。从机收到主机发送出8 位信号后,会回应一个 ACK 信号;接着送出寄存器地址Register Address[7:0],从机收到主机发送出8 位信号后,会回应一个 ACK 信号;接着主机重新送出开始信号SR(restart),再由主机发送出欲控制的器件地址DeviceAddress[6:0],再加上 1 位的 W/R 读写位(设定为 1)。从机收到主机发送出8 位信号后,会回应 一个 ACK 信号。接着读取 8 位数据 Data[7:0],主机收到8 位信号后发送一个NACK给从机,通知从机主机不再需要更多的数据,最后从主机送出停止信号SP:

9a99bad8-dae8-11f0-8c8f-92fbcf53809c.png

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

    关注

    1663

    文章

    22492

    浏览量

    638937
  • 通信协议
    +关注

    关注

    28

    文章

    1094

    浏览量

    42336
  • 接收器
    +关注

    关注

    15

    文章

    2651

    浏览量

    77493
  • I2C总线
    +关注

    关注

    8

    文章

    422

    浏览量

    63488

原文标题:4-DE10-Nano的HDMI方块移动案例——I2C通信协议

文章出处:【微信号:友晶FPGA,微信公众号:友晶FPGA】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    3分钟理解通信协议I2C总线 #通信协议

    通信协议I2CI2C总线总线/接口技术
    硬声课堂
    发布于 :2021年10月18日 10:39:12

    i2c通信协议

    1.1 i2c通信协议通信协议:用来实现数据传输。i2c物理总线:SCL(时钟线) SDA(数据线)i2c
    发表于 03-06 16:15

    I2C通信协议硬软件

    目录12C通信协议硬软件I2CAHT20测温湿度参考12C通信协议I2C
    发表于 08-23 07:42

    I2C通信协议简介

    一.I2C通信协议简介1.物理层I2C物理层有以下特点:I2C是支持多设备的总线,支持多个通讯主机、多个通讯从机I2C使用两条总线线路,SD
    发表于 01-13 07:20

    I2C通信协议的原理是什么

    I2C通信协议I2C通信原理I2C通信原理:I2C
    发表于 02-17 07:16

    I2C总线通信协议的相关资料下载

    基于I2C总线通信协议的温度采集实验(基于AHT20) I2C总线通信协议简介 AHT20简介 一.项目说明1)实战目标:2)实战元件: 二
    发表于 02-22 07:37

    SPI、I2C、UART串行总线协议

    串口通讯通信协议UART,以及常用外设通信协议 SPI、I2C的介绍与他们之间的区别
    发表于 11-30 11:28 96次下载

    实验八-I2C通信协议

    实验八-I2C通信协议,感兴趣的可以瞧一瞧。
    发表于 09-22 16:42 2次下载

    I2C通信协议应该如何学习

    我最近刚做完I2C通信协议的编写与调试,下面介绍一下我从一开始理解夏老师的程序,修改程序,直到下板调试整个的学习过程,希望对大家学习 I2C 有一定的帮助。一、 分析源代码学习 I2C
    发表于 04-28 08:00 22次下载
    <b class='flag-5'>I2C</b><b class='flag-5'>通信协议</b>应该如何学习

    什么是I2C通信协议

    在本教程中,我们将学习如何在Raspberry Pi Pico中使用I2C引脚并遍历I2C扫描器代码。
    的头像 发表于 04-26 15:08 9184次阅读
    什么是<b class='flag-5'>I2C</b><b class='flag-5'>通信协议</b>?

    MPU6050的I2C通信协议

    不同硬件有不同的I2C协议
    发表于 12-06 12:21 3次下载
    MPU6050的<b class='flag-5'>I2C</b><b class='flag-5'>通信协议</b>

    i2c和spi通信协议的概念与区别 I2C/SPI总线通信协议你搞懂没有

    计划第四期:硬声UP主@硬件研究狮 从工程实践的角度,给大家拆解I2C与SPI。     四分钟搞定通信协议的分类 简介: 同步通信与异步通信,全双工
    的头像 发表于 06-23 17:19 5223次阅读

    I2C通信协议:了解I2C Primer、 PMBus和SMBus

    I2C,即Inter-Integrated Circuit,是一种常用的串行通信协议,用于在器件之间——特别是两个或两个以上不同电路之间建立通信I2C Primer是最常用的
    的头像 发表于 06-15 15:29 8619次阅读
    <b class='flag-5'>I2C</b><b class='flag-5'>通信协议</b>:了解<b class='flag-5'>I2C</b> Primer、 PMBus和SMBus

    SPI和I2C通信协议:应用与区别

    本文深入解析了SPI和I2C这两种通信协议的特点、工作原理和应用场景。SPI适用于高速数据传输,常用于存储器芯片和显示器驱动等领域;I2C适用于低速控制和传感器数据传输,常用于温度传感器和ADC
    的头像 发表于 04-22 16:45 3889次阅读

    简单认识I2C通信协议

    I2C(Inter-Integrated Circuit)通信协议是由飞利浦公司(现为恩智浦半导体)开发的一种简单、双向二线制同步串行总线协议。自1982年发布以来,I2C
    的头像 发表于 07-25 18:06 3934次阅读