news 2026/4/16 12:22:38

5-DE10-Nano的HDMI方块移动案例——基于FPGA的I2C控制模块设计

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
5-DE10-Nano的HDMI方块移动案例——基于FPGA的I2C控制模块设计

I2C_WRITE_WDATA.v模块实现I2C写时序,I2C_Controller (I2C控制器)例化了I2C_WRITE_WDATA.v模块,同时增加了I2C数据线SDA的三态缓冲电路。I2C_HDMI_Config.v 是顶层模块,该模块例化了I2C_Controller模块,对系统时钟进行了分频,并控制寄存器的配置。


1 I2C写操作的Verilog实现


I2C_WRITE_WDATA.v是一个I2C写数据模块,用于通过I2C总线向从设备ADV7513写入数据。


该模块接口定义如下:


该模块实现了一个状态机,其功能是向从设备写入多个字节数据。它按照I2C协议生成起始条件、发送从设备地址(包括读/写位)、发送数据字节以及产生停止条件。同时,它还会检测从设备的应答信号,并在传输完成后给出结束信号。具体过程如下图:

为了能更好的理解这个状态机的控制逻辑,下面画出I2C传输某个寄存器的过程波形如下:


2 I2C的三态门电路Verilog实现


I2C_Controller.v里面例化了一个I2C_WRITE_WDATA.v模块:


该模块将I2C_WRITE_WDATA.v模块的SDAI 和SDAO 之间增加了一个三态门电路:


在I2C_WRITE_WDATA模块中,SDAO是输出信号,用于控制数据线的输出状态。当需要输出高电平时,SDAO设置为1,使得I2C_SDAT为高阻,由上拉电阻拉高;当需要输出低电平时,SDAO设置为0,将I2C_SDAT拉低。同时,I2C_WRITE_WDATA模块还接收SDAI(即I2C_SDAT)作为输入,用于读取总线上的实际状态(例如检测ACK信号)。


3 I2C配置寄存器的Verilog设计


这是一个HDMI的寄存器配置模块,它使用了一个查找表(LUT)来存储配置数据,然后通过I2C控制器(实现了I2C协议)对HDMI transmitter的寄存器逐个进行写入配置。


时钟分频


一般FPGA开发板板载系统时钟是50MHz, 但是I2C 的时钟不能太高,从手册上看, 最大不能超过400KHz,所以设计代码的时候需要分频。


Verilog代码里面将50MHz时钟分频为20KHz时钟:


配置寄存器


寄存器配置的值通过查找表(LUT)来存储, 代码里面主要配置了31个寄存器,其他的没有配置的就表示使用的是默认的配置,有关于ADV7513的寄存器查找请参考2 ADV7513寄存器配置章节。


寄存器数据的配置采用一个三状态的状态机去控制:

状态机完整代码如下:

这个状态机确保了HDMI配置数据的可靠传输,具备完整的错误处理和重试机制,是HDMI初始化过程中的核心控制逻辑。


I2C设备地址


ADV7513的PD引脚接2K电阻到地:

参考ADV7513_Hardware_User's_Guide_R0.pdf文档可知其I2C读、写地址是0x72/0x73:


HDMI_TX_INT信号


HDMI_TX_INT信号低电平有效,具体描述可以参考ADV7513_Hardware_User's_Guide_R0.pdf的第17页:


在DE10-Nano的开发板电路中,

该引脚默认被拉高到3.3V,当触发中断事件发生时,由软件控制该信号发生电平变化。


I2C_HDMI_Config.v文件里面设置若HDMI_TX_INT信号为低电平,则重新配置寄存器:

往期阅读

1-DE10-Nano的HDMI方块移动案例——显示器时序(DMT)标准介绍

2-DE10-Nano的HDMI方块移动案例——HDMI接口介绍(含TMDS)

3-DE10-Nano的HDMI方块移动案例——ADV7513芯片解读

4-DE10-Nano的HDMI方块移动案例——I2C通信协议

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 16:46:48

MBA必看!9个降AIGC工具高效避坑指南

MBA必看!9个降AIGC工具高效避坑指南 AI降重工具:MBA论文的高效护航者 在当今学术环境中,随着AI技术的广泛应用,论文中出现的AIGC痕迹越来越容易被检测系统识别。对于MBA学生而言,一篇高质量的论文不仅需要逻辑清晰、内…

作者头像 李华
网站建设 2026/4/15 12:26:13

【AI落地新突破】:Open-AutoGLM在安卓设备上的低延迟部署秘籍

第一章:Open-AutoGLM在安卓端部署的背景与意义随着移动计算能力的持续提升,将大型语言模型(LLM)部署至终端设备成为实现低延迟、高隐私交互的关键路径。Open-AutoGLM作为一款开源的自动推理生成语言模型,具备轻量化结构…

作者头像 李华
网站建设 2026/4/16 10:18:00

Open-AutoGLM内测申请常见被拒原因:90%开发者都踩过的5个坑

第一章:Open-AutoGLM内测申请常见被拒原因概述在申请 Open-AutoGLM 内测资格时,许多开发者因未满足平台设定的审核标准而被拒绝。了解这些常见原因有助于提升申请成功率,避免因基础疏漏错失参与机会。申请信息填写不完整或虚假 平台要求申请人…

作者头像 李华
网站建设 2026/4/15 22:18:04

28、Elasticsearch集群扩展、节点管理与升级全攻略

Elasticsearch集群扩展、节点管理与升级全攻略 1. 集群高可用性与副本分片 在维护测试索引的高可用性时,可创建更多副本分片。当节点丢失时,若所有主分片可用,数据会进行复制。例如,Node2上的test0和test3主分片数据会复制到Node3的副本中,Node3上的test1主分片数据会复…

作者头像 李华
网站建设 2026/4/12 9:19:54

33、Elasticsearch性能优化:缓存、堆内存与性能权衡策略

Elasticsearch性能优化:缓存、堆内存与性能权衡策略 在使用Elasticsearch时,性能优化是一个关键问题。合理利用缓存、平衡JVM堆内存与操作系统缓存,以及在不同场景下做出合适的性能权衡,都能显著提升系统的性能和效率。 1. 过滤器执行选项 在运行过滤器时,有三种主要选…

作者头像 李华
网站建设 2026/4/16 10:13:25

35、Elasticsearch性能优化与集群管理全解析

Elasticsearch性能优化与集群管理全解析 在使用Elasticsearch的过程中,性能优化和集群管理是至关重要的环节。下面我们将详细介绍如何提升性能以及进行有效的集群管理。 性能优化相关要点 不同查询类型的性能考量 DFS查询 :DFS查询由于额外的网络调用而速度较慢。在切换…

作者头像 李华