工具与大脑完美结合,才能写出世上最棒的Verilog代码

2024-01-25 00:30

本文主要是介绍工具与大脑完美结合,才能写出世上最棒的Verilog代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

69e9b5bda700151ceaa5b709fd6eb701.png

工具与大脑完美结合,才能写出世上最棒的Verilog代码

EDA工具的利与弊

很多新生代的FPGA工程师都没使用过使用原理图输入进行FPGA设计,没有经历过那些“画原理图和连线”的工作,这得益于HDL(Hardware Description Language) 硬件描述语言和语言综合工具及其它EDA相关工具的推广,使广大的工程师的工作重心从底层连线上转移到功能实现上。

从这方面讲EDA工具极大地提高了工作效率,而且随着这些工具的发展整个FPGA设计越来越方便,尤其一些高级语言的引入让整个FPGA开发效率越发提高,但是还是需要警惕EDA工具的“弊端”。

现在越来越多的FPGA工程师基本只关心功能的实现,而基本不关心自己的电路实现形式,都是以功能为目标,后期的优化交给工具就OK了。

这种思想的的后果就是在用HDL描述电路时(大部分以为自己写的是程序),脑袋里没有或者非常模糊的电路概念,对于代码后期的综合成什么样子和映射(route)到FPGA芯片后是什么样子完全没想法,这样做的后果就是完全没有充分利用FPGA的特点和结构,一旦遇到工具不能解决的问题,自己就束手无策,这就是过份依赖工具的后果。

HDL和FPGA是怎么“牵手”的

HDL转换成FPGA可以运行的“程序”得益于两个过程:Synthesis 和 Optimization。Synthesis是把行为级描述通过算法转换为门级的描述,这个过程是与约束没有关系的;Optimization的作用则是把上一步的门级描述在用户的约束作用下(约束的重要性)通过算法映射到FPGA的单元结构上。

整个过程如下图所示:

05ae1a650773bbaadc86a215ab72f207.png

所以我们发现HDL的设计是会间接影响到最后的结果的,也就是我们的Code Style不一样Synthesis部分就已经大部分决定了最后的设计的性能。简单举个例子:

16选1选择器:

当我们使用case这一算法级描述的时候,综合结果如下:

dc0f1a89d58557322ee8abf1d9f3682c.png

当我们使用内部BUFT进行描述时(BUFT可以参考:http://blog.sina.com.cn/s/blog_ea3189e20102wzhl.html),综合结果如下:

1d64759e2b3e0b84eba696433f351fc3.png

也就是说,我们不同的Code Style,最后的综合、实现结果也是不一样的。

最后我们也知道现在大部分FPGA由查找表(LUT)、时序单元和一些先进结构组成(进位链等),由于最小单元固定,所以基本单元的延时是固定的,我们在设计代码时需要充分考虑使用了多少级查找表或者进位链,这样我们可以尽可能的减少延时,所以在设计时我们就需要考虑好如何根据FPGA的器件特点更好的利用FPGA资源。

关于FPGA的器件特点推荐《简谈 Xilinx FPGA 原理及结构》和《FPGA原理和结构PDF》。

进行大型逻辑设计时,布局规划也是我们需要考虑的问题,这里就不展开赘述了,可以查看《FPGA 的布局规划艺术》。

总结

上面说了这么多,无非就是想让大家明白:不要过分依赖工具,如果把整个FPGA设计看做是化学变化的话,那么我们使用的工具只是起到催化剂的作用,我们自己的知识、设计技巧及Code Style才是参加这一化学变化的反应分子,才是最重要的因素(突然想到2H2O——2H2↑+O2↑,难受!)。所以我们需要将自己写作的Code Style和工具、FPGA特点结合起来,这样才能写出最棒的代码。

这里说几个常用的Code Style:

1、减少扇出-高扇出会造成布线延时变长;2、复位方案-复位的选择对性能是有影响的,根据厂家的推荐选择合适的复位方式;3、使用专用布局布线资源-可以根据需求选择专用的低延时布线资源;。。。

上面只是简单说了几个,这里推荐华为的Code Style文档《华为经典FPGA设计全套入门技巧资料分享》作为参考,后续可以根据自己的习惯和经验进行修改。

fed4d7d7979eb77f9e3e124b7489f9ab.png

你真的理解Verilog 中的module吗?


47d36d27e56411f7adfe1afe45cf8923.png

优秀的 Verilog/FPGA开源项目介绍(十一)- SPI/SPI FLASH/SD卡


04be063b8eb8c637d27c2aa8be609670.png

Zynq MPSOC 电子书免费下载


c418a16fe2bcc0c8e0a38d4b79656ffe.png

基于FPGA的数字识别-实时视频处理的定点卷积神经网络实现


这篇关于工具与大脑完美结合,才能写出世上最棒的Verilog代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/641540

相关文章

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1

超强的截图工具:PixPin

你是否还在为寻找一款功能强大、操作简便的截图工具而烦恼?市面上那么多工具,常常让人无从选择。今天,想给大家安利一款神器——PixPin,一款真正解放双手的截图工具。 想象一下,你只需要按下快捷键就能轻松完成多种截图任务,还能快速编辑、标注甚至保存多种格式的图片。这款工具能满足这些需求吗? PixPin不仅支持全屏、窗口、区域截图等基础功能,它还可以进行延时截图,让你捕捉到每个关键画面。不仅如此

html css jquery选项卡 代码练习小项目

在学习 html 和 css jquery 结合使用的时候 做好是能尝试做一些简单的小功能,来提高自己的 逻辑能力,熟悉代码的编写语法 下面分享一段代码 使用html css jquery选项卡 代码练习 <div class="box"><dl class="tab"><dd class="active">手机</dd><dd>家电</dd><dd>服装</dd><dd>数码</dd><dd