工具与大脑完美结合,才能写出世上最棒的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

相关文章

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指