news 2026/6/15 19:23:39

例说FPGA:可直接用于工程项目的第一手经验【2.9】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
例说FPGA:可直接用于工程项目的第一手经验【2.9】

12.7 Verilog代码解析

本实例分为4个层级,大大小小共计25个模块,其层次结构如图12-27所示。

各个模块的基本功能定义如表12-2所示。

表12-2 Verilog各个模块功能描述

1.vip.v模块代码解析

略。

2.sys_ctrl.v模块代码解析

略,请参考例程工程实例1。

3.ddr2_controller.v模块代码解析

略,请参考例程工程实例2。

4.ddr_avl_bridge.v模块代码解析

该模块用于衔接DDR2控制器IP核与用户逻辑,即adv7180_ctrl.v模块产生的两个通道(分别由奇场和偶场还原的完整视频帧)视频流通过该模块写入到DDR2存储器中,而DDR2存储器中的视频流又通过该模块送往lcd_driver.v模块,用于LCD的显示。该模块的功能框图如图12-28所示。该模块例化了3个FIFO,两个用于缓存写入DDR2数据的缓存,一个用于DDR2读出数据的缓存。

仲裁逻辑部分的数据读写状态机切换如图12-29所示。

5.led_controller.v模块代码解析

略,请参考例程工程实例1。

6.lcd_driver.v模块代码解析

略,请参考例程工程实例9。

7.adv7180_ctrl.v模块代码解析

该模块包含了6个子模块,即iic_ctrl.v模块、tviic_debug.v模块、dbcheck_ctrl.v模块、dbfir模块以及两个ycbcr2rgb.v模块。该模块主要是对6个子模块进行例化,实现它们之间的接口连接以及和外部的接口连接。该模块及其下所有子模块之间的连接和功能示意如图12-30所示。

8.tviic_debug.v模块代码解析

该模块是直接例化了IP核,它的IP核配置参考后续的IP核配置部分内容。在adv7180_ctrl模块中,对该模块的例化代码如下所示。

//例化In-System Sources and Probes对ADV7180的IIC接口做实时调试tviic_debug tviic_debug_inst (

.probe ( tiic_rddb ),

.source ( {tiic_en,tiic_wr_rdn,tiic_ab,tiic_wrdb} )

);

例化的两个接口信号probe和source,顾名思义,probe就是探针,用于连接FPGA逻辑的输出信号,便于用户在Quartus II集成的In-System Probes and Sources Editor中进行实时的监控;而source,即源,表示它作为FPGA逻辑信号的一个“源”输入进来,这样,在我们的In-System Probes and Sources Editor中就可以给FPGA的某些输入信号产生激励,从而达到在线调试的目的。

probe和sorce信号都可以是任意定义位宽,我们将它们连接到FPGA逻辑中,并且引到可以进行控制或检测的输入或输出信号上。这个实例中,我们连接的信号都是和IIC时序产生逻辑iic_ctrl.v模块的信号,通过这些接口,我们就可以任意地读写ADV7180的IIC寄存器。接口信号的功能映射如表12-3所示。

9.iic_ctrl.v模块代码解析

略,设计的思路和工程实例9的iic_ctrl.v模块基本一致,请参考那里的详细解析。

10.dbcheck_ctrl.v模块代码解析

该模块实现最前端的视频流的采集,对视频协议进行解析。因此在对代码进行详解之前,我们不得不多花一些篇幅来认识一下我们所使用的AV视频解码芯片ADV7180以及它用于传输视频数据流的协议格式。

如图12-31所示,这是ADV7180芯片的内部功能框图。从图示可以看到,这颗芯片无非是对模拟的AV视频信号进行采样、AD转换、数字处理以获得期望的数字视频流信号(这些步骤我们称之为“AV解码”),并且按帧对视频流编码为ITU-R BT.656(我们简称ITU656)送出。我们的FPGA端就连接着ITU656送数据的数字总线,通过这些接口,我们就

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

React Native + OpenHarmony:ImageSVG图片渲染

React Native OpenHarmony:ImageSVG图片渲染 摘要 在跨平台移动应用开发中,SVG(可缩放矢量图形)因其分辨率无关性和优秀的文件体积特性,成为图标和插图的理想选择。本文基于AtomGitDemos实战项目,深入探…

作者头像 李华
网站建设 2026/6/15 12:35:29

互联网大厂Java面试:从Spring Cloud到分布式事务的技术场景解析

互联网大厂Java面试:从Spring Cloud到分布式事务的技术场景解析 场景设定 在某互联网大厂的面试室,严肃的面试官李云龙坐在桌前,而面试者谢宝庆则是以搞笑著称的“水货程序员”。此次面试的场景围绕电商场景展开,技术点涵盖Spring…

作者头像 李华
网站建设 2026/6/15 12:38:42

安全工具篇Go魔改二开Fscan扫描FRP代理特征消除新增扩展打乱HASH

免杀对抗——第一百六十五天 安全工具篇&Go魔改二开&Fscan扫描&FRP代理&特征消除&新增扩展&打乱HASH 安全工具 - Goland-FRP魔改二开&特征消除 FRP是一种快速的反向代理,允许你将位于NAT或防火墙后的本地服务器暴露在互联网上。目前…

作者头像 李华
网站建设 2026/6/15 12:35:56

React Native + OpenHarmony:View视图溢出处理

React Native OpenHarmony:View视图溢出处理 在React Native跨平台开发中,布局容器的边界控制是构建稳定用户界面的基石。当子组件的尺寸超出父容器时,如何优雅地处理溢出内容,直接关系到应用的视觉呈现与交互体验。本文将基于R…

作者头像 李华
网站建设 2026/6/15 14:30:03

新春有礼!网易小派云音乐版 License 免费拿!

新春有礼, “AI”相伴2月4日-4月4日,网易小派新春专属流量扶持正式来袭!“网易小派”是网易智企旗下云信业务推出的 AIoT 智能体平台。当前,网易小派具备视频、图片、实时语音、文字等多模态交互,具备记忆引擎、故事引…

作者头像 李华